zoukankan      html  css  js  c++  java
  • 慎用@@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()返回了我们想要的值。

  • 相关阅读:
    「SHOI2015」脑洞治疗仪
    LOJ 数列分块入门 8
    CF932F Escape Through Leaf
    NOIP2021游记总结
    [HEOI2016/TJOI2016]序列
    【模板】动态树(Link Cut Tree)
    LG P2839 [国家集训队]middle
    JZOJ 7377.欢乐豆
    JZOJ 7392. 【2021.11.17NOIP提高组联考】数 (ds)
    LOJ 数列分块入门 6
  • 原文地址:https://www.cnblogs.com/tian2010/p/2867083.html
Copyright © 2011-2022 走看看