@@IDENTITY与SCOPE_IDENTITY()_数据库文摘

来源:脚本之家  责任编辑:小易  

起个别名的意思

在一条 INSERT、SELECT INTO 或大容量复制语句完成后,@@IDENTITY 中包含语句生成的最后一个标识值。如果语句未影响任何包含标识列的表,则 @@IDENTITY 返回 NULL。如果插入了多个行,生成了多个标识值,则 @@IDENTITY 将返回最后生成的标识值。如果语句触发了一个或多个触发器,该触发器又执行了生成标识值的插入操作,那么,在语句执行后立即调用 @@IDENTITY 将返回触发器生成的最后一个标识值。如果对包含标识列的表执行插入操作后触发了触发器,并且触发器对另一个没有标识列的表执行了插入操作,则 @@IDENTITY 将返回第一次插入的标识值。出现 INSERT 或 SELECT INTO 语句失败或大容量复制失败,或者事务被回滚的情况时,@@IDENTITY 值不会恢复为以前的设置。

sql="insert into adminuser values('ddd

      如果语句和事务失败,它们会更改表的当前标识,从而使标识列中的值出现不连贯现象。即使未提交试图向表中插入值的事务,也永远无法回滚标识值。例如,如果因 IGNORE_DUP_KEY 冲突而导致 INSERT 语句失败,表的当前标识值仍然会增加。

谢谢邀请,我认为对于新手宝妈来说,纸尿裤和纸尿片都可以,端看经济情况和阶段性的。纸尿片我一开始用的时候挺好用的,那时候宝宝护肚脐的药还有,纸尿片不会滑走,宝宝肚脐一不用药了,就不那么好用了。因为便宜让宝爸多买了几包,后来只有搭配纸尿裤用,换的纸尿裤有便便的时候,抽出旧的垫在那里,防止便便弄到床上。最后来宝宝三个多月还没用完,是买了几条尿布兜兜住了用,纸尿片就是没有魔术贴的纸尿裤,价钱会比纸尿裤便宜,用法和尿布是一样的。纸尿裤因为一定要抬起宝宝的屁股,放好后面有魔术贴的那头,才能把魔术贴黏到前面这头。新生儿因为频繁的需要更换,甚至刚换好又拉了,有时候宝宝睡眠中也需要更换,纸尿裤就没有纸尿片方便,

     @@IDENTITY、SCOPE_IDENTITY 和 IDENT_CURRENT 是相似的函数,因为他们都返回插入到表的 IDENTITY 列的最后一个值。

“队魂\"应该就是一支球队的灵魂,在他身上可以反映出球队的特点,可以体现出球队的精气神,球队会因他的存在和不存在而变得不同的两个样,如果细分的话,我觉得应该还可以分为两种队魂,一种的话是战术上的,一种是精神上的,当然也有两种并存的情况出现。这样的队魂,我第一个想到的毫无疑问是1986年世界杯的阿根廷队,马拉多纳是那支球队无可争议的灵魂,无论是精神上还是战术上他都是绝对的领袖!战术上:那届大赛的7场比赛中,阿根廷队共打进14个进球,其中13个进球都和马拉多纳息息相关。马拉多纳攻入5球、助攻5次,一个人直接成就了其中的10球!并间接参与了另外3球!1986年世界杯是一种战术的成功,阿根廷主帅比拉尔

     @@IDENTITY 和 SCOPE_IDENTITY 可以返回当前会话中的所有表中生成的最后一个标识值。但是,SCOPE_IDENTITY 只在当前作用域内返回值,而 @@IDENTITY 不限于特定的作用域。

如果是同价位的话,相信大部分人都会和我一样选择苹果手机,毕竟档次更高,而且拿出去有面子。不过这两年来国产手机提升的很快,创新,颜值和性能都有很大的提升,尤其是体验感非常不错。苹果手机这几年来确实让人很失望,没有快充也就算了,电池容量也不大,而且创新力太弱了,几乎和iPhone6s没什么很大的区别,价格也不稳定,目前还在降价中,估计不少人都在观望,降到最低的时候才买,不过苹果系统不错,使用两年还流畅,这一点很多国产手机都比不上。当然现在不少人都喜欢国产手机,要我选vivoX9Plus的可能性会更大,不仅颜值高,拍照效果好,还有双引擎闪充技术,充电快,而且系统也很流畅,还有微信分身,分屏等功能,很

     IDENT_CURRENT 不受作用域和会话的限制,而受限于指定的表。IDENT_CURRENT 可以返回任何会话和任何作用域中为特定表生成的标识值。

含着金钥匙出生的她,在圈里面摸爬滚打多年,但是却从来没有绯闻,43岁的她身家百亿,如今人工授精的2个儿子也是十分帅气。这个她,其实大家并不是陌生,她就是香港天后陈慧琳。陈慧琳能歌善舞,比较耳熟能详的歌曲比如《记事本》《不如跳舞》《花花宇宙》等等。陈慧琳舞蹈性感,歌曲旋律朗朗上口,成为了多少人心中的女神。陈慧琳,1973年9月13日出生于香港湾仔区,香港女歌手、演员,毕业于纽约帕森斯设计学院。1999年至2000年在十大劲歌金曲颁奖典礼上获得最受欢迎女歌星奖。其实可能很多人都不知道,陈慧琳出身于香港珠宝大亨家庭,香港三分之二的珠宝店都是她父亲开的,可谓是名副其实的大家千金啊。感觉自己肾需要补,对

     @@IDENTITY 函数的作用域是执行该函数的本地服务器上的当前会话。此函数不能应用于远程或链接服务器。若要获得其他服务器上的标识值,请在远程服务器或链接服务器上执行存储过程,并使(在远程或链接服务器的环境中执行的)该存储过程收集标识值,并将其返回本地服务器上的发出调用的连接。

     以下示例向包含标识列 (LocationID) 的表中插入一行,并使用 @@IDENTITY 显示新行中使用的标识值:

复制代码 代码如下:

USE AdventureWorks;

GO

--Display the value of LocationID in the last row in the table.

SELECT MAX(LocationID) FROM Production.Location;

GO

INSERT INTO Production.Location (Name, CostRate, Availability, ModifiedDate)

VALUES ('Damaged Goods', 5, 2.5, GETDATE());

GO

SELECT @@IDENTITY AS 'Identity';

GO

--Display the value of LocationID of the newly inserted row.

SELECT MAX(LocationID) FROM Production.Location;

GO

补充:

  我们要慎用@@IDENTITY,原因是 @@IDENTITY 它总是获取最后一条变更数据的自增字段的值,

 而忽略了进行变更操作所在的范围约束。比如,我有表 A 和表 B 两个表,现在我在表 A 上定义了一个Insert触发器,当在表 A 中插入一条数据时,自动在表 B 也插入一条数据。此时,大家注意,有两个原子操作:在A中插入一条数据, 接着在B中随后插入一条数据。

   现在我们想下,假设上面表 A 和表 B 都有IDENTITY自增域,那么我们在表 A 插入一条数据后,使用了 SELECT @@IDENTITY 输出时,输出的到底是 A 还是 B 的自增域的值呢?  答案很明显,是谁最后插入就输出谁,那么就是 B 了。于是,我本意是想得到 A 的自增域值,结果得到了 B 的自增域值,一只 BUG 随之诞生,搞不好还会影响到整个系统数据的混乱。

   因此,对于这种情况,建议大家慎用 @@IDENTITY,而尽量采用 SCOPE_IDENTITY()函数替换之。SCOPE_IDENTITY() 也是得到最后一条自增域的值,但是它是仅限在一个操作范围之内,而不@@IDENTITY 是取全局操作的最后一步操作所产生的自增域的值的。

扩展阅读,根据您访问的内容系统为您准备了以下内容,希望对您有帮助。

scope_identity()这个函数是用做什么啊?

SCOPE_IDENTITY

返回插入到同一作用域中的 IDENTITY 列内的最后一个 IDENTITY 值。一个作用域就是一个模块——存储过程、触发器、函数或批处理。因此,如果两个语句处于同一个存储过程、函数或批处理中,则它们位于相同的作用域中。

语法

SCOPE_IDENTITY( )

返回类型

sql_variant

注释

SCOPE_IDENTITY、IDENT_CURRENT 和 @@IDENTITY 在功能上相似,因为它们都返回插入到 IDENTITY 列中的值。

IDENT_CURRENT 不受作用域和会话的*,而受限于指定的表。IDENT_CURRENT 返回为任何会话和作用域中的特定表所生成的值。有关更多信息,请参见 IDENT_CURRENT。

SCOPE_IDENTITY 和 @@IDENTITY 返回在当前会话中的任何表内所生成的最后一个标识值。但是,SCOPE_IDENTITY 只返回插入到当前作用域中的值;@@IDENTITY 不受限于特定的作用域。

例如,有两个表 T1 和 T2,在 T1 上定义了一个 INSERT 触发器。当将某行插入 T1 时,触发器被激发,并在 T2 中插入一行。此例说明了两个作用域:一个是在 T1 上的插入,另一个是作为触发器的结果在 T2 上的插入。

假设 T1 和 T2 都有 IDENTITY 列,@@IDENTITY 和 SCOPE_IDENTITY 将在 T1 上的 INSERT 语句的最后返回不同的值。

@@IDENTITY 返回插入到当前会话中任何作用域内的最后一个 IDENTITY 列值,该值是插入 T2 中的值。

SCOPE_IDENTITY() 返回插入 T1 中的 IDENTITY 值,该值是发生在相同作用域中的最后一个 INSERT。如果在作用域中发生插入语句到标识列之前唤醒调用 SCOPE_IDENTITY() 函数,则该函数将返回 NULL 值。

有关说明,请参见示例。

示例

下列示例将创建两个表 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 TZ

VALUES ('Lisa')

INSERT TZ

VALUES ('Mike')

INSERT TZ

VALUES ('Carla')

SELECT * FROM TZ

--Result set: This is how table TZ looks

Z_id Z_name

-------------

1 Lisa

2 Mike

3 Carla

CREATE 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

BEGIN

INSERT TY VALUES ('')

END

/*FIRE the trigger and find out what identity values you get

with the @@IDENTITY and SCOPE_IDENTITY functions*/

INSERT TZ VALUES ('Rosalie')

SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY]

GO

SELECT @@IDENTITY AS [@@IDENTITY]

GO

--Here is the result set.

SCOPE_IDENTITY

4

/*SCOPE_IDENTITY returned the last identity value in the same scope, which was the insert on table TZ*/

@@IDENTITY

115

/*@@IDENTITY returned the last identity value inserted to TY by the trigger, which fired due to an earlier insert on TZ*/

参考资料:联机帮助文档

ASP中scope_identity()如何获取返回的ID

这个不知道写在一起可不可以,你分开两个SQL语句看看sql="insert into adminuser values('ddd','ddd',0,getdate(),1)"cnn.execute(sql)sql="select scope_identity()"set rs=cnn.execute(sql)

为什么select SCOPE_IDENTITY()返回值为空呢?

插入语句values列表错了,values('{0}','{1}',{2},'{3}',{4},'{5}',{6},default,default,default)"

还没列完你就加)括号了

【有疑问可以HI我,或追问,但请不要关闭问题,谢谢!】追问插入是对的

这个User表里有id列,主键,自动加1。但是用select SCOPE_IDENTITY() 查这个最近生成的id返回确实空的。而表里的id也确实+1了。我需要获得这个新生成id,有没有别的办法?

sqlSCOPE_IDENTITY()

在存储过程里,定义一个输出参数,

把 SCOPE_IDENTITY()值赋给输出参数返回,

然后前台获得,赋给 TEXTBOX1 完事

不知道你有没有用过输出参数,没有的话,查一下,一两句话也说不清楚的

  • 本文相关:
  • sql添加数据后返回受影响行数据
  • sqlserver中向表中插入多行数据的insert语句
  • 用js获得表格当前行数的代码
  • 向数据库中插入数据并返回当前插入的行数及全局变量@@identity应用
  • @@identity与scope_identity()
  • sqlite中的b-tree实现细节分析
  • sqlite 中文指南之faq
  • 数据库连接方式汇总
  • 比较sql server与oracle、db2
  • scope_identity()这个函数是用做什么啊?
  • ASP中scope_identity()如何获取返回的ID
  • 为什么select SCOPE_IDENTITY()返回值为空呢?
  • sql SCOPE_IDENTITY()
  • 急!请问Work-related identity in individual and social...
  • SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY] 。 前面的A...
  • ASP中scope_identity()如何获取返回的ID
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页数据库文摘sql添加数据后返回受影响行数据sqlserver中向表中插入多行数据的insert语句用js获得表格当前行数的代码向数据库中插入数据并返回当前插入的行数及全局变量@@identity应用@@identity与scope_identity()sqlite中的b-tree实现细节分析sqlite 中文指南之faq数据库连接方式汇总比较sql server与oracle、db2sqlite 中文指南之faq数据库连接方式汇总比较sql server与oracle、db2sqlite中的b-tree实现细节分析@@identity与scope_identity()比较sql server与oracle、db2@@identity与scope_identity()sqlite中的b-tree实现细节分析数据库连接方式汇总sqlite 中文指南之faq
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved