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

作者: harde 分类: 数据库 发布时间: 2011-05-18 15:44

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

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

;select @@identity

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

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

;select SCOPE_IDENTITY()

;select IDENT_CURRENT('table')

举例

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

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

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注