慎用@@IDENTITY,用SCOPE_IDENTITY()代替之
2013-01-18 23:05
363 查看
从msdn中,我们知道两者的定义是:
@@IDENTITY: 返回最后插入的标识值的系统函数
SCOPE_IDENTITY():返回插入到同一作用域中的标识列内的最后一个标志值
使用@@IDENTITY时,如果插入语句触发了一个或多个触发器,而触发器又执行了生成标识值的插入操作,
那么,在插入语句后面调用@@IDENTITY时,获取到的就不是你所希望得到的值了。
我们来举个例子:
由此可见,使用@@IDENTITY返回了非预期的值,而SCOPE_IDENTITY()返回了我们想要的值。
@@IDENTITY: 返回最后插入的标识值的系统函数
SCOPE_IDENTITY():返回插入到同一作用域中的标识列内的最后一个标志值
使用@@IDENTITY时,如果插入语句触发了一个或多个触发器,而触发器又执行了生成标识值的插入操作,
那么,在插入语句后面调用@@IDENTITY时,获取到的就不是你所希望得到的值了。
我们来举个例子:
--要执行插入语句的表 create table ident_ins_table(id int identity(1,1),name varchar(10)) --触发器执行插入语句的表 create table ident_trigger(id int identity(1,1),name varchar(20)) --先插入测试数据 insert into ident_trigger(name)values('row1'),('row2'),('row3') --获取当前的标志值 select IDENT_CURRENT('ident_trigger')
--创建一个触发器,使其在对ident_ins_table执行插入之后, --再插入一条记录到ident_trigger create trigger testident on ident_ins_table after insert as insert into ident_trigger(name)values('insert by trigger')
--插入ident_ins_table表后,获取标志值 insert into ident_ins_table(name)values('test') select @@IDENTITY select SCOPE_IDENTITY()
输出值为:
由此可见,使用@@IDENTITY返回了非预期的值,而SCOPE_IDENTITY()返回了我们想要的值。
相关文章推荐
- 使用SCOPE_IDENTITY()代替@@IDENTITY的原因
- @@IDENTITY、IDENT_CURRENT、SCOPE_IDENTITY的区别
- @@IDENTITY 和 SCOPE_IDENTITY() 的区别
- @@IDENTITY与SCOPE_IDENTITY()
- SQL 获取最新ID,scope_identity() ,@@identity,ident_current
- 关于如何使用SqlServer中@@Identity、@@IDENT_CURRENT、@@SCOPE_Identity获取自动生成列的值的区别(精简版)
- @@identity , SCOPE_IDENTITY,IDENT_CURRENT 三者的异同
- SCOPE_IDENTITY和@@identity的区别
- @@IDENTITY与SCOPE_IDENTITY()
- 解析@@IDENTITY与SCOPE_IDENTITY()(转)
- @@identity , SCOPE_IDENTITY,IDENT_CURRENT 三者的异同
- SCOPE_IDENTITY和@@identity的区别[转]
- @@identity , SCOPE_IDENTITY,IDENT_CURRENT 三者的异同
- SCOPE_IDENTITY和@@identity的区别 【转】
- @@IDENTITY,IDENT_CURRENT,SCOPE_IDENTITY,IDENT_INCR,IDENT_SEED详解
- A. 将 @@IDENTITY 和 SCOPE_IDENTITY 用于触发器
- SCOPE_IDENTITY、IDENT_CURRENT和@@IDENTITY的比较
- SCOPE_IDENTITY和@@identity的区别
- 转载:SCOPE_IDENTITY、IDENT_CURRENT和@@IDENTITY比较
- 放弃SCOPE_Identity,使用OUTPUT代替