Foxtable(狐表)用户栏目专家坐堂 → 关于Insert into 执行后,如何同时获得该行的_Identify 值


  共有2522人关注过本帖树形打印复制链接

主题:关于Insert into 执行后,如何同时获得该行的_Identify 值

帅哥哟,离线,有人找我吗?
有点甜
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2017/8/27 23:28:00 [显示全部帖子]

方法一:

 

https://www.baidu.com/baidu?wd=insert+into++OUTPUT

 

方法二:

 

插入多少行都没问题的啊,报什么错?贴出网站代码。


 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2017/8/29 11:36:00 [显示全部帖子]

Dim cmd As New SQLCommand
cmd.ConnectionName = "test"
cmd.CommandText = "Insert Into abc (第一列, 第二列) output inserted._Identify Values('A','B')"
msgbox(cmd.ExecuteScalar)

 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2017/8/29 11:55:00 [显示全部帖子]

你本来的代码就没问题啊

 

Dim cmd As New SQLCommand
cmd.ConnectionName = "test"
cmd.CommandText = "Insert Into abc (第一列, 第二列) output inserted._Identify Values('A','B');update abc set 第三列 = @@IDENTITY where _Identify = @@IDENTITY"
msgbox(cmd.ExecuteScalar)
cmd.CommandText = "Insert Into abc (第一列, 第二列) output inserted._Identify Values('A','B');update abc set 第三列 = @@IDENTITY where _Identify = @@IDENTITY"
msgbox(cmd.ExecuteScalar)


 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2017/8/29 12:15:00 [显示全部帖子]

不能用union all,必须一条一条插入,才能得到主键值。

 

你可以最后执行update语句整体修改dw的值啊,如

 

update 配方信息表 set DW = _Identify where dw Is null or dw <> _Identify


 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2017/8/30 14:54:00 [显示全部帖子]

Union All 这种可能会快一些。不过其实差不多。

 

最后一次性update不就好了?


 回到顶部