找回密码  加入

AUTOIT CN

搜索
查看: 345|回复: 8

[系统综合] [已解决] MsSQL 如何在插入行时同时获取自增ID

[复制链接]
发表于 2018-4-13 10:53:15 | 显示全部楼层 |阅读模式
本帖最后由 yhxhappy 于 2018-4-15 12:13 编辑

表有两列,结构是这样:ID int identity(1,1) PRIMARY KEY, Model varchar(30)
第1列ID每插入一行自动递增

现在可以做到先插入行,再查询表的最新ID,但这样做法缺点是,在查询ID之前如果其他用户又插入一行,得到的ID值就是错误的。

所以想在插入行的同时获取该行的ID。
在 SQL Server Management Studio 中按以下操作可以实现:
INSERT "表" ("MODEL") VALUES (115) SELECT @@IDENTITY


以下代码已更新,可以解决我的问题。
  1. Func _MsSQL_InsertTable($Obj, $Table, $Field, $Value)                        ;插入行,字段与值对应,可部分或完全填写
  2.    If Not IsObj($Obj) Then
  3.           SetError(1)
  4.           Return 0
  5.    ElseIf $Table = "" Or $Field = "" Or $Value = "" Then
  6.           SetError(4)
  7.           Return 0
  8.    EndIf

  9.    $FieldArray = StringSplit($Field, ",")
  10.    $ValueArray = StringSplit($Value, ",")
  11.    If $FieldArray[0] <> $ValueArray[0] Then
  12.           SetError(2)
  13.           Return 0
  14.    EndIf

  15.    Local $FieldText = "", $ValueText
  16.    For $i = 1 To $ValueArray[0]
  17.           $ValueText &= "'" & $ValueArray[$i] & "',"
  18.    Next
  19.    $ValueText = StringTrimRight($ValueText, 1)

  20.    $RS = ObjCreate("ADODB.Recordset")
  21.    $RS.ActiveConnection = $Obj

  22.    ConsoleWrite("SELECT MAX(ID)+1 FROM "& $Table &" INSERT " & $Table & " (" & $Field & ") VALUES (" & $ValueText & ")" & @CRLF)
  23.    $RS.Open("SELECT MAX(ID)+1 FROM "& $Table &" INSERT " & $Table & " (" & $Field & ") VALUES (" & $ValueText & ")")
  24.    If @error Then
  25.           SetError(3)
  26.           Return 0
  27.    EndIf

  28.    $ID = $RS.Fields(0).value
  29.    $RS.close
  30.    Return $ID
  31. EndFunc
复制代码

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?加入

x
发表于 2018-4-14 19:55:06 | 显示全部楼层
如果你的数据库存在同时多人更新数据的情况,那么你应该使用SCOPE_IDENTITY() 函数,而不是@@IDENTITY。因为@@IDENTITY返回的值是不区分作用域的,如果你在A表插入了一条数据,同时有人在B表插入数据,那你将会返回来自B表的@@IDENTITY值。
至于查询语句可以试试Select SCOPE_IDENTITY()  as id
发表于 2018-4-15 01:42:45 | 显示全部楼层
回复 1# yhxhappy

UPDATE 跟 INSERT 之後不會返回任何值

所以要返回的資料 要再 一開始就處理

你的語法改一下應該就有結果

SELECT MAX(ID)+1  FROM XXXX
INSET INTO....................

然後 用 RS OPEN 去執行 就會返回 SELECT MAX(ID)+1  FROM XXXX  的結果

但是 你的目的是甚麼??  其實 這都不是最安全的方式
最安全的方式 是鎖表  把表 LOCK 只有你可以新增 查詢  等你做完你要做的  別人才可以繼續處理....
 楼主| 发表于 2018-4-15 09:42:16 | 显示全部楼层
本帖最后由 yhxhappy 于 2018-4-15 10:54 编辑

回复 3# kk_lee69

MAX(ID)+1  如果ID列会自动叠加(ID int identity(1,1)),再加下这个动作会不会重复?
还有能不能把 这两行合到一行来写。因为我感觉AU3操作SQL,步骤越多出错的机率越多,还要做很多判断。
SELECT MAX(ID)+1  FROM XXXX
INSET INTO....................

我目的是想检查刚写入的数据是否写入成功。

比如我写入了一行 123456
为保险起见,再重新读取行数据看是否已存在。但有可能表上以前就写过相同的一行,返回结果不好判断。
所以想通过唯一的 ID 来判断是否成功。
 楼主| 发表于 2018-4-15 10:51:56 | 显示全部楼层
回复 2# 298311657

谢谢提醒,因为对SQL不熟悉没考虑到这些细节。

在 SQL Server Management Studio 中按以下操作可以返回ID:
INSERT "表" ("MODEL") VALUES (115) Select SCOPE_IDENTITY()

主要问题是 RS OPEN 不知道怎么获取它的返回值。
发表于 2018-4-15 11:25:00 | 显示全部楼层
回复 4# yhxhappy

你肯定沒做吧

SELECT MAX(ID)+1  FROM XXXX
INSET INTO....................


寫成一行 不就是

SELECT MAX(ID)+1  FROM XXXX      INSET INTO....................

你肯定沒實際測試  你可以試看看  不信那我也沒辦法了
发表于 2018-4-15 11:30:56 | 显示全部楼层
本帖最后由 kk_lee69 于 2018-4-15 11:32 编辑

回复 4# yhxhappy

【我目的是想检查刚写入的数据是否写入成功。

比如我写入了一行 123456
为保险起见,再重新读取行数据看是否已存在。但有可能表上以前就写过相同的一行,返回结果不好判断。
所以想通过唯一的 ID 来判断是否成功。】

你的話 是有 瑕疵  
你說 比如我寫入了一行 123456  這表示 是資料內容吧  而不是 ID
卻又說 可能以前就寫過相同的一行

如果是 這樣  以前的 123456 跟現在的123456  兩個ID 不會一樣的  一樣你無法判斷以前是否寫過...

如果 你的 123456 本身指的就是ID  那你又何必要寫入呢??

寫入前先判定ID是否存在就好阿
发表于 2018-4-15 11:43:28 | 显示全部楼层
回复 1# yhxhappy

27 行 改為

$RS.Open(" SELECT MAX(ID)+1 FROM "&$Table &"  INSERT " & $Table & " (" & $Field & ") VALUES (" & $ValueText & ") ")
 楼主| 发表于 2018-4-15 12:11:37 | 显示全部楼层
回复 8# kk_lee69


    谢谢帮助,解决了我的问题。
您需要登录后才可以回帖 登录 | 加入

本版积分规则

QQ|小黑屋|手机版|AUTOIT CN ( 鲁ICP备15028933号-3 )谷歌 百度

GMT+8, 2018-12-14 08:14 , Processed in 0.097556 second(s), 15 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表