如何得到自增id值
如何得到自增id值
如何得到SqlServer的自增ID:
SqlServer中的自增的ID的最后的值:
SELECT SCOPE_IDENTITY() --返回插入到同一作用域中的 IDENTITY 列內(nèi)的最后一個(gè) IDENTITY 值。
SELECT @@IDENTITY?? --返回插入到當(dāng)前會(huì)話(huà)中任何作用域內(nèi)的最后一個(gè) IDENTITY 列值
SELECT IDENT_CURRENT('TbName')--不受作用域和會(huì)話(huà)的限制,而受限于指定的表。IDENT_CURRENT 返回為任何會(huì)話(huà)和作用域中的特定表所生成的值。
一個(gè)作用域就是一個(gè)模塊——存儲(chǔ)過(guò)程、觸發(fā)器、函數(shù)或批處理。因此,如果兩個(gè)語(yǔ)句處于同一個(gè)存儲(chǔ)過(guò)程、函數(shù)或批處理中,則它們位于相同的作用域中。
參考的例子如下:
USE pubs
DROP TABLE t6
DROP TABLE t7
GO
CREATE TABLE t6(id int IDENTITY)
CREATE TABLE t7(id int IDENTITY(100,1))
GO
CREATE TRIGGER t6ins ON t6 FOR INSERT
AS
BEGIN
?? INSERT t7 DEFAULT VALUES
?? SELECT @@IDENTITY as [@@IDENTITY]
?? SELECT SCOPE_IDENTITY() as [SCOPE_IDENTITY]
END
GO
--end of trigger definition
SELECT?? * FROM t6
--id is empty.
SELECT?? * FROM t7
--id is empty.
--Do the following in Session 1
INSERT t6 DEFAULT VALUES
SELECT @@IDENTITY?????
/*Returns the value 100, which was inserted by the trigger.*/
SELECT SCOPE_IDENTITY()??
/* Returns the value 1, which was inserted by the
INSERT stmt 2 statements before this query.*/
return
SELECT IDENT_CURRENT('t7')
/* Returns value inserted into t7, i.e. in the trigger.*/
SELECT IDENT_CURRENT('t6')
/* Returns value inserted into t6, which was the INSERT statement 4 stmts before this query.*/
-- Do the following in Session 2
SELECT @@IDENTITY
/* Returns NULL since there has been no INSERT action
so far in this session.*/
SELECT SCOPE_IDENTITY()
/* Returns NULL since there has been no INSERT action
so far in this scope in this session.*/
SELECT IDENT_CURRENT('t7')
/* Returns the last value inserted into t7.*/
總結(jié):
對(duì)于馬上使用的剛才插入的新記錄ID用SCOPE_IDENTITY()是最合適的;
對(duì)于想要得到一系列的操作中最后得到的那個(gè)自增的ID最好用@@IDENTITY;
對(duì)于想要得到一個(gè)表中的最后一個(gè)插入操作所產(chǎn)生的ID的最好用IDENT_CURRENT('TBName')
?
出處:http://blog.csdn.net/greatplain/archive/2004/11/15/181948.aspx
總結(jié)
- 上一篇: Linux 的mv命令
- 下一篇: Android 创世纪 第二天