insert into 后获得自动插入的id(select @@identity)
做软件时常常遇到这样的情况~对于有自动增长列的表,我们在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 返回为当前会话和当前作用域中的任何表最后生成的标识值