高手请进,速度结帖! INSERT INTO Table1 (idttt)VALUES ('aaa'); SELECT @@IDENTITY这个行。C#里 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 @@IDENTITY返回最后插入的标识值的系统函数。在一条 INSERT、SELECT INTO 或大容量复制语句完成后,@@IDENTITY 中包含语句生成的最后一个标识值。如果语句未影响任何包含标识列的表,则 @@IDENTITY 返回 NULL。如果插入了多个行,生成了多个标识值,则 @@IDENTITY 将返回最后生成的标识值。如果语句触发了一个或多个触发器,该触发器又执行了生成标识值的插入操作,那么,在语句执行后立即调用 @@IDENTITY 将返回触发器生成的最后一个标识值。如果对包含标识列的表执行插入操作后触发了触发器,并且触发器对另一个没有标识列的表执行了插入操作,则 @@IDENTITY 将返回第一次插入的标识值。出现 INSERT 或 SELECT INTO 语句失败或大容量复制失败,或者事务被回滚的情况时,@@IDENTITY 值不会恢复为以前的设置。如果语句和事务失败,它们会更改表的当前标识,从而使标识列中的值出现不连贯现象。即使未提交试图向表中插入值的事务,也永远无法回滚标识值。例如,如果因 IGNORE_DUP_KEY 冲突而导致 INSERT 语句失败,表的当前标识值仍然会增加。 @@IDENTITY、SCOPE_IDENTITY 和 IDENT_CURRENT 是相似的函数,因为他们都返回插入到表的 IDENTITY 列的最后一个值。@@IDENTITY 和 SCOPE_IDENTITY 可以返回当前会话中的所有表中生成的最后一个标识值。但是,SCOPE_IDENTITY 只在当前作用域内返回值,而 @@IDENTITY 不限于特定的作用域。IDENT_CURRENT 不受作用域和会话的限制,而受限于指定的表。IDENT_CURRENT 可以返回任何会话和任何作用域中为特定表生成的标识值。有关详细信息,请参阅 IDENT_CURRENT (Transact-SQL)。@@IDENTITY 函数的作用域是执行该函数的本地服务器上的当前会话。此函数不能应用于远程或链接服务器。若要获得其他服务器上的标识值,请在远程服务器或链接服务器上执行存储过程,并使(在远程或链接服务器的环境中执行的)该存储过程收集标识值,并将其返回本地服务器上的发出调用的连接。复制可能会影响 @@IDENTITY 值,因为该值在复制触发器及存储过程中使用。如果此列是复制项目的一部分,则 @@IDENTITY 不是最近用户创建的标识的可靠指示器。您可以使用 SCOPE_IDENTITY() 函数语法代替 @@IDENTITY。有关详细信息,请参阅 SCOPE_IDENTITY (Transact-SQL) 的“示例”部分。注意: 必须重新编写执行调用的存储过程或 Transact-SQL 语句才能使用 SCOPE_IDENTITY() 函数。这将返回用户语句范围内所用的最新标识,而不是复制所用的嵌套触发器范围内的标识。 create table ta(ID int ,school varchar(10))insert into ta select 1,'a'create proc Getprocasselect * from ta where (ID=1)delete from ta where (ID=1)drop proc Getprocdrop table ta SQL 企业管理器里执行不了。 菜鸟:sql2000字段int添加空值后输出总显示0如何去掉? 关于差异更新问题,求解啊 求解... 请教如何查询是哪2个查询或存储过程导致的死锁,谢谢 必须声明变量 '@pid'???? 这个Sql语句怎样写? 如何批量产生随机数! 正则表达式写不到数据库中,字符串被自动截掉了 !!!!!紧急求救,数据库高手 sql2005 数据库同步报错 为何数据库备份不能使用? 查询的结果可能为空,如果记录为空想手工赋一条记录可以吗? 菜鸟来了
返回最后插入的标识值的系统函数。
在一条 INSERT、SELECT INTO 或大容量复制语句完成后,@@IDENTITY 中包含语句生成的最后一个标识值。如果语句未影响任何包含标识列的表,则 @@IDENTITY 返回 NULL。如果插入了多个行,生成了多个标识值,则 @@IDENTITY 将返回最后生成的标识值。如果语句触发了一个或多个触发器,该触发器又执行了生成标识值的插入操作,那么,在语句执行后立即调用 @@IDENTITY 将返回触发器生成的最后一个标识值。如果对包含标识列的表执行插入操作后触发了触发器,并且触发器对另一个没有标识列的表执行了插入操作,则 @@IDENTITY 将返回第一次插入的标识值。出现 INSERT 或 SELECT INTO 语句失败或大容量复制失败,或者事务被回滚的情况时,@@IDENTITY 值不会恢复为以前的设置。如果语句和事务失败,它们会更改表的当前标识,从而使标识列中的值出现不连贯现象。即使未提交试图向表中插入值的事务,也永远无法回滚标识值。例如,如果因 IGNORE_DUP_KEY 冲突而导致 INSERT 语句失败,表的当前标识值仍然会增加。 @@IDENTITY、SCOPE_IDENTITY 和 IDENT_CURRENT 是相似的函数,因为他们都返回插入到表的 IDENTITY 列的最后一个值。@@IDENTITY 和 SCOPE_IDENTITY 可以返回当前会话中的所有表中生成的最后一个标识值。但是,SCOPE_IDENTITY 只在当前作用域内返回值,而 @@IDENTITY 不限于特定的作用域。IDENT_CURRENT 不受作用域和会话的限制,而受限于指定的表。IDENT_CURRENT 可以返回任何会话和任何作用域中为特定表生成的标识值。有关详细信息,请参阅 IDENT_CURRENT (Transact-SQL)。@@IDENTITY 函数的作用域是执行该函数的本地服务器上的当前会话。此函数不能应用于远程或链接服务器。若要获得其他服务器上的标识值,请在远程服务器或链接服务器上执行存储过程,并使(在远程或链接服务器的环境中执行的)该存储过程收集标识值,并将其返回本地服务器上的发出调用的连接。复制可能会影响 @@IDENTITY 值,因为该值在复制触发器及存储过程中使用。如果此列是复制项目的一部分,则 @@IDENTITY 不是最近用户创建的标识的可靠指示器。您可以使用 SCOPE_IDENTITY() 函数语法代替 @@IDENTITY。有关详细信息,请参阅 SCOPE_IDENTITY (Transact-SQL) 的“示例”部分。注意:
必须重新编写执行调用的存储过程或 Transact-SQL 语句才能使用 SCOPE_IDENTITY() 函数。这将返回用户语句范围内所用的最新标识,而不是复制所用的嵌套触发器范围内的标识。
insert into ta select 1,'a'
create proc Getproc
asselect * from ta where (ID=1)
delete from ta where (ID=1)drop proc Getproc
drop table ta