慎用@@IDENTITY,用SCOPE_IDENTITY()代替之

从msdn中,我们知道两者的定义是:

@@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()
输出值为:

image

 

由此可见,使用@@IDENTITY返回了非预期的值,而SCOPE_IDENTITY()返回了我们想要的值。

转载于:https://www.cnblogs.com/tian2010/archive/2013/01/18/2867083.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值