通过程序获得SQL数据库中的GetKey函数
创始人
2024-07-13 13:50:58
0

下面将为您介绍通过程序获得SQL Server自增型字段的函数--GetKey函数的方法,供您参考,希望对你更好学习SQL中函数能够有所帮助。

概述:

通过程序来产生自增型字段,可以避免多用户操作的读取脏数据,操作也很简便.可以更好的在程序中控制这些关键字段的数值.

关键步骤:

1. 创建用于存放需要自增的数据表.(systemkey)

SQL Script 如下:

  1. if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[SystemKey]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)   
  2. drop table [dbo].[SystemKey]   
  3. GO   
  4.    
  5. CREATE TABLE [dbo].[SystemKey] (   
  6.     [ID] [int] NOT NULL ,   
  7.     [KeyName] [nvarchar] (50)  NOT NULL ,   
  8.     [KeyValue] [int] NOT NULL ,   
  9.     [SourceID] [nvarchar] (50)  NOT NULL ,   
  10.     [LockTime] [datetime] NULL    
  11. ) ON [PRIMARY]   
  12. GO   
  13.   

 KeyName:关键字的字段名(我们需要的字段名称,手工添加到这个表中)

KeyValue:对应字段名的值.

SourceID:字段的来源,如果没有可以填””

LockTime:锁定的时间,在程序内部使用.

2. GetKeys函数方程,通过调用GetKeys函数得到关键字的值.

函数描述如下:

  1. Imports Microsoft.ApplicationBlocks.Data   
  2. Imports Microsoft.VisualBasic.CompilerServices   
  3. Imports System.Threading   
  4. Imports System.Data.SqlClient   
  5. Public Class ClassTestClass ClassTest   
  6.     Public Function GetKeys()Function GetKeys(ByVal KeyName As String, ByVal Source As String, ByVal CNString As String) As Integer   
  7.         Dim connection As New SqlConnection(CNString)   
  8.    
  9.         Dim NewNum As Integer   
  10.         Dim obj2 As Object   
  11.         Dim sFlage As String = "Flag"   
  12.         Try   
  13.             Dim sql As String   
  14.             Dim time As DateTime = DateAndTime.Now.AddSeconds(1)   
  15.             connection.Open()   
  16.             Do While (StringType.StrCmp(sFlage, "", False) <> 0)   
  17.                 sql = (("Update [SystemKey] Set [SourceID]='" & Source & "', [LockTime]=GetDate()  Where [KeyName]='" & KeyName) & "' AND   ((DATEADD(millisecond, 1000, LockTime) 
  18.                 Dim j As Integer = SqlHelper.ExecuteNonQuery(connection, CommandType.Text, sql)   
  19.                 If (j > 0) Then   
  20.                     sFlage = ""   
  21.                     Exit Do   
  22.                 End If   
  23.                 sFlage = "Err"   
  24.                 connection.Close()   
  25.                 If (DateTime.Compare(time, DateAndTime.Now) < 0) Then   
  26.                     Return -1   
  27.                 End If   
  28.                 Thread.Sleep(10)   
  29.             Loop   
  30.    
  31.             sql = "Select KeyValue  From [SystemKey] Where [KeyName]='" & KeyName & "' AND SourceID='" & Source & "'"   
  32.             Dim OldNum As Object = SqlHelper.ExecuteScalar(connection, CommandType.Text, sql)   
  33.             Dim num As Integer = (IntegerType.FromObject(OldNum) + 1)   
  34.             sql = "Update [SystemKey] Set [KeyValue]=" & StringType.FromInteger(num) & ", [SourceID]='' Where [KeyName]='" & KeyName & "'"   
  35.             SqlHelper.ExecuteNonQuery(connection, CommandType.Text, sql)   
  36.             NewNum = num   
  37.         Catch exception As Exception   
  38.             NewNum = -1   
  39.         Finally   
  40.             If Not connection Is Nothing Then   
  41.                 CType(connection, IDisposable).Dispose()   
  42.             End If   
  43.         End Try   
  44.         Return NewNum   
  45.     End Function   
  46. End Class   
  47.   

 

 

 

【编辑推荐】

SQL中DATENAME函数的用法

SQL中循环语句的效果实例

SQL中类似For循环处理的实例

对存储过程代替SQL语句的讨论

SQL聚合函数之Avg 函数

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
规避非法攻击 用好路由器远程管... 单位在市区不同位置设立了科技服务点,每一个服务点的员工都通过宽带路由器进行共享上网,和单位网络保持联...
范例解读VB.NET获取环境变... VB.NET编程语言的使用范围非常广泛,可以帮助开发人员处理各种程序中的需求,而且还能对移动设备进行...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...