您的位置:首页 > 运维架构

SCOPE_IDENTITY的用法

2018-02-03 11:03 441 查看
SCOPE_IDENTITY   和   @@IDENTITY   的作用都是取得返回在当前会话中的任何表内所生成的最后一个标识值,简单的说就是在执行一条插入语句之后使用@@IDENTITY的全局变量,取得插入记录的ID号但是有个问题就是,@@IDENTITY是全局的,所以在他的功能会体现在所有作用域,一个操作,一个触发器,一个存储过程叫做一个作用域,这时候如果出现多个作用域的情况的时候,@@IDENTITY所取得的ID号就是最后一个作用域产生的结果。这时候我们要使用SCOPE_IDENTITY方法来作了。SCOPE_IDENTITY
  只返回插入到当前作用域中的值;@@IDENTITY   不受限于特定的作用域。  

  使用方法:select   SCOPE_IDENTITY()   as   ID   from   select   @@IDENTITY   as   ID   from  
 

  实例:  

        sql="SET   NOCOUNT   ON;insert   into  
(Item)   values('"&Item&"')"sql=sql&";select   @@IDENTITY   as   ID   from  
;SET   NOCOUNT   OFF;"  

在插入某些自增表的时候,需要将其打开:

 语法:SET   IDENTITY_INSERT   TableName   ON
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: