@@identity、scope_identity()、IDENT_CURRENT('tablename')函数的区别
@@IDENTITY 和SCOPE_IDENTITY 返回在当前会话中的任何表内所生成的最后一个标识值。但是,SCOPE_IDENTITY 只返回插入到当前作用域中的值;@@IDENTITY 不受限于特定的作用域。
例如,有两个表 T1 和 T2,并且在 T1 上定义了 INSERT 触发器。当将某行插入 T1 时,触发器被激发,并在 T2 中插入一行。 该方案演示了两个作用域:在 T1 上的插入,以及在 T2 通过触发器的插入。
假设 T1 和 T2 都有标识列,@@IDENTITY 和 SCOPE_IDENTITY 将在 T1 上的 INSERT 语句的最后返回不同的值。@@IDENTITY 将返回在当前会话中的任何作用域内插入的最后一个标识列的值。这是在 T2 中插入的值。SCOPE_IDENTITY() 将返回在 T1 中插入的 IDENTITY 值。这是在同一个作用域内发生的最后的插入。如果在任何 INSERT 语句作用于作用域中的标识列之前调用 SCOPE_IDENTITY() 函数,则该函数将返回空值。
如果语句和事务失败,它们会更改表的当前标识,从而使标识列中的值出现不连贯现象。即使未提交试图向表中插入值的事务,也永远无法回滚标识值。例如,如果因 IGNORE_DUP_KEY 冲突而导致 INSERT 语句失败,表的当前标识值仍然会增加。
以下示列创建两个表,TZ
和 TY
,并在 TZ
中创建一个 INSERT 触发器。当将某行插入表 TZ
中时,触发器 (Ztrig
) 将激发并在 TY
中插入一行。
USE tempdb GO CREATE TABLE TZ (Z_id int IDENTITY(1,1)PRIMARY KEY,Z_name varchar(20) NOT NULL)INSERT TZVALUES ('Lisa') INSERT TZVALUES ('Mike') INSERT TZVALUES ('Carla')SELECT * FROM TZ--Result set: This is how table TZ looks. Z_id Z_name ------------- 1 Lisa 2 Mike 3 CarlaCREATE TABLE TY (Y_id int IDENTITY(100,5)PRIMARY KEY,Y_name varchar(20) NULL)INSERT TY (Y_name)VALUES ('boathouse') INSERT TY (Y_name)VALUES ('rocks') INSERT TY (Y_name)VALUES ('elevator')SELECT * FROM TY --Result set: This is how TY looks: Y_id Y_name --------------- 100 boathouse 105 rocks 110 elevator/*Create the trigger that inserts a row in table TY when a row is inserted in table TZ*/ CREATE TRIGGER Ztrig ON TZ FOR INSERT AS BEGININSERT TY VALUES ('')END/*FIRE the trigger and determine what identity values you obtain with the @@IDENTITY and SCOPE_IDENTITY functions.*/ INSERT TZ VALUES ('Rosalie')SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY] GO SELECT @@IDENTITY AS [@@IDENTITY] GO
下面是结果集:
SCOPE_IDENTITY 4 /*SCOPE_IDENTITY returned the last identity value in the same scope. This was the insert on table TZ.*/@@IDENTITY 115 /*@@IDENTITY returned the last identity value inserted to TY by the trigger. This fired because of an earlier insert on TZ.*/ http://www.cnblogs.com/MingDe/archive/2011/10/12/2208749.html
USE [tempdb] GOCREATE TABLE [dbo].[MainTB]([Id] [int] IDENTITY(1,1) NOT NULL,[Name] [nvarchar](50) NULL,CONSTRAINT [PK_MainTB] PRIMARY KEY CLUSTERED ([Id] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY]GOCREATE TABLE [dbo].[SubTB]([Id] [int] IDENTITY(100,5) NOT NULL,[Memo] [nvarchar](50) NULL,[MainKeyId] [int] NOT NULL,CONSTRAINT [PK_SubTB] PRIMARY KEY CLUSTERED ([Id] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY]GOALTER TABLE [dbo].[SubTB] WITH CHECK ADD CONSTRAINT [FK_SubTB_MainTB] FOREIGN KEY([MainKeyId]) REFERENCES [dbo].[MainTB] ([Id]) GOALTER TABLE [dbo].[SubTB] CHECK CONSTRAINT [FK_SubTB_MainTB] GO----------------------------------------------------INSERT INTO dbo.MainTB(Name) SELECT '張三'SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY] SELECT @@IDENTITY AS [@@IDENTITY] SELECT IDENT_CURRENT('MainTB') SELECT IDENT_CURRENT('SubTB')----------------------------------------------------INSERT INTO dbo.MainTB(Name) SELECT '李四' UNION ALL SELECT '王五'SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY] SELECT @@IDENTITY AS [@@IDENTITY] SELECT IDENT_CURRENT('MainTB') SELECT IDENT_CURRENT('SubTB')----------------------------------------------------INSERT INTO dbo.MainTB(Name) SELECT '李四' UNION ALL SELECT '王五'INSERT INTO dbo.SubTB(Memo) SELECT '備註一' UNION ALL SELECT '備註二'SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY] SELECT @@IDENTITY AS [@@IDENTITY] SELECT IDENT_CURRENT('MainTB') SELECT IDENT_CURRENT('SubTB')----------------------------------------------------------- INSERT INTO dbo.MainTB(Name) SELECT '李四' UNION ALL SELECT '王五'INSERT INTO dbo.SubTB(Memo,MainKeyId) SELECT '備註一',1 UNION ALL SELECT '備註二',1SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY] SELECT @@IDENTITY AS [@@IDENTITY] SELECT IDENT_CURRENT('MainTB') SELECT IDENT_CURRENT('SubTB') ----------------------------------------------------------- CREATE TRIGGER trgTEST ON MainTB FOR INSERT AS BEGININSERT INTO dbo.SubTB(Memo,MainKeyId) SELECT '備註一',SCOPE_IDENTITY()ENDINSERT INTO dbo.MainTB(Name) SELECT '李四'SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY] SELECT @@IDENTITY AS [@@IDENTITY] SELECT IDENT_CURRENT('MainTB') SELECT IDENT_CURRENT('SubTB') ------------------------------------------------------INSERT INTO dbo.MainTB(Name) SELECT '李四' WAITFOR DELAY '00:00:20' SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY] SELECT @@IDENTITY AS [@@IDENTITY] SELECT IDENT_CURRENT('MainTB') SELECT IDENT_CURRENT('SubTB') SELECT * FROM dbo.MainTB SELECT * FROM dbo.SubTB--新开查询窗同时执行以下Script INSERT INTO dbo.MainTB(Name) SELECT '李四' SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY] SELECT @@IDENTITY AS [@@IDENTITY] SELECT IDENT_CURRENT('MainTB') SELECT IDENT_CURRENT('SubTB') SELECT * FROM dbo.MainTB SELECT * FROM dbo.SubTB
IDENT_CURRENT('MainTB'):取表的最后编号,注意如果在高并发下,可能会取的不是预期的结果。
@@identity、scope_identity()、IDENT_CURRENT('tablename')函数的区别相关推荐
- SCOPE_IDENTITY()、 @@IDENTITY 、 IDENT_CURRENT()
SQL Server 中,可以使用 SCOPE_IDENTITY(). @@IDENTITY . IDENT_CURRENT() 来取得最后插入记录的值值,它们的区别在于: SCOPE_IDENTIT ...
- c语言scanf与gets区别,C语言 scanf()和gets()函数的区别
C语言 scanf()和gets()函数的区别 1.相同点:scanf( )函数和gets( )函数都可用于输入字符串 2.不同点:两者在功能上有所区别,具体区别如下: 要实现如下需求"从控 ...
- render函数和redirect函数的区别+反向解析
render函数和redirect函数的区别+反向解析 1.视图函数:一定是要包含两个对象的(render源码里面有HttpResponse对象) request对象:----->所有的请求 ...
- 友元函数、类的非静态成员函数、静态成员函数的区别
类中申明的函数相对于类来说有三层意思: 1.有this指针 2.函数在类的作用区域中 3.可以访问类中私有部分 4.可以被继承 非静态成员函数具有1234 静态成员函数具有234 友元函数具有3 静态 ...
- 第七周项目一-成员函数、友元函数和一般函数有区别(1)
/**Copyright(c)2016,烟台大学计算机与控制工程学院*All rights reserved*文件名称:123.cpp*作 者:王蕊*完成日期:2016年4月12日*版 本 号: ...
- php怎么输出3个函数和,PHP利用var_dump,var_export,print_r三个函数的区别示例
感兴趣的小伙伴,下面一起跟随512笔记的小玲来看看吧!下面的示例看看这三个函数的具体的区别,其中var_dump和var_export比较少用,但他们两者又很相似.所以可以看看: 代码如下: /* 5 ...
- python 类和函数的区别
python中,在类中可以定义函数,类和函数都可作为一个模块保存. python的类和函数的区别主要在于类可以有变量和各种方法,而函数没有. 函数只能被运行,返回或者不返回值都可以. 模块如果没有把类 ...
- Python中str()与repr()函数的区别——repr() 的输出追求明确性,除了对象内容,还需要展示出对象的数据类型信息,适合开发和调试阶段使用...
Python中str()与repr()函数的区别 from:https://www.jianshu.com/p/2a41315ca47e 在 Python 中要将某一类型的变量或者常量转换为字符串对象 ...
- python split(), os.path.split()和os.path.splitext()函数的区别
python split(), os.path.split()和os.path.splitext()函数的区别 文章目录: 1. split() 2. os.path.split() 3. os.pa ...
最新文章
- a标签居中 img vue_Vue中img的src属性绑定与static文件夹实例
- GHOST装双系统图文教程
- 上海德拓人工智能事业部招聘图像算法工程师
- windows防火墙ntp服务器_NTP教学续集已发送,请你查收!
- C++---内存泄漏与防范
- 千万别把有本事挣钱的人,当成臭奸商
- 红帽为开发订阅成员提供的免费福利
- 51单片机学习——1天学完普中基本实验例程,走马观花式学习,大家切勿效仿。
- 牛客网高级项目课总结
- 光能手写板 android,一种液晶光能手写板的制作方法
- Vue源码学习 -- 响应式原理之观察者模式
- html边框倾斜,弯曲的边框CSS实现
- apollo(阿波罗) 分布式部署指南
- 详解IP地址和Mac地址
- 类似捕鱼达人的金币效果
- b站黑马Vue2后台管理项目笔记——(1)登录功能
- 错误笔记:JavaWeb:请求的资源[/$%7BpageContext.request.contextPath%7D/login]不可用
- python3 列表长度_3种在Python中查找列表长度的简便方法
- AndroidStudio找不到模拟器,也无法连接手机,提示adb.exe start-server' failed -- run manually if necessary...
- MFC IPAddressCtrl控件的使用
热门文章
- Oracle Logminer 做数据恢复 说明示例
- (原創) 我的Design Pattern之旅[3]:使用template改進Strategy Pattern (OO) (Design Pattern) (C/C++) (template)...
- C# 8的Ranges和递归模式
- 时钟同步和时钟修正的小技巧
- 简单快速的开发WEB应用, PHP 框架 Lemon 介绍
- fisher's exact test
- Windows Server 2012 R2工作文件夹⑨:自动发现设置
- DLR学习笔记(01)
- InteWidgetTookit现有三个控件的使用方法
- 分页技巧_实现第一个分页功能(回复列表中的分页)