记录Harde学习成长生活的点点滴滴.
« »
2011-05-18
数据库

200 次浏览

insert into 后获得自动插入的id(select @@identity)

做软件时常常遇到这样的情况~对于有自动增长列的表,我们在insert 以后想要得到自动增长的id~

在MSSQL下做到很容易,在你的insert语句末尾加上@@identity是绝大多数学生或新手的做法~

1
;select @@identity

但事实上,并不推荐使用@@identity来获取自动增长值~
因为@@IDENTITY 返回值,是当前会话的“所有作用域”中的任何表最后生成的标识值。
有很大的不确定性

所以建议使用SCOPE_IDENTITY()与IDENT_CURRENT(‘表名’)代替
所以推荐的写法是

1
2
3
;select SCOPE_IDENTITY()
 
;select IDENT_CURRENT('table')

举例

1
insert into UserInfo values('admin');select IDENT_CURRENT('UserInfo') as id

注解:
IDENT_CURRENT 返回为任何会话和任何作用域中的特定表最后生成的标识值。
IDENT_CURRENT 不受作用域和会话的限制,而受限于指定的表。
SCOPE_IDENTITY 返回为当前会话和当前作用域中的任何表最后生成的标识值

日志信息 »

该日志于2011-05-18 15:44由 harde 发表在数据库分类下, 你可以发表评论。除了可以将这个日志以保留源地址及作者的情况下引用到你的网站或博客,还可以通过RSS 2.0订阅这个日志的所有评论。

相关日志 »

随机日志

没有评论

发表评论 »

使用新浪微博登陆

返回顶部
分享按钮