亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

在SQL Server 中如何得到剛剛插入的標識值

添加時間:2012-4-12  添加: admin 

數據庫實際應用中,我們往往需要得到剛剛插入的標志值來往相關表中寫入數據。但我們平常得到的真的是我們需要的那個值么?

有時我們會使用

SELECT @@Identity

來獲得我們剛剛插入的值,比如下面的代碼

 

代碼一:
use tempdb
if exists (select * from sys.objects where object_id = object_id(N'[test1]') and type in (N'u'))
drop table [test1]
go
create table test1
(
id int identity(1,1),
content nvarchar(100)
)
insert into test1 (content)
values ('solorez')
select @@identity

樂觀情況下,這樣做是沒問題的,但如果我們如果先運行下面的代碼二創建一個觸發器、再運行代碼三:

 

代碼二:
create table test2
(
id int identity(100,1),
content nvarchar(100)
)

create trigger tri_test1_identitytest_I
on test1 after insert
as
begin
insert into test2
select content from inserted
end
 

 

代碼三:
insert into test1 (content)
values ('solorez2')
select @@identity
 

我們可以看到,此時得到的標識值已經是100多了,很明顯,這是表test2的生成的標識值,已經不是我們想要的了。

我們可以看看@@identity的定義:Identity

原來,@@identity返回的是當前事務最后插入的標識值。

這時我們或許會用下面的方法:

 

代碼四:
insert into test1 (content)
values ('solorez3')
SELECT IDENT_CURRENT('test1')
 

看來結果還比較正確,但如果我們在多次運行代碼四的同時運行下面的代碼五:

 

代碼五:
insert into test1 (content)
values ('solorez3')

waitfor delay '00:00:20'
SELECT IDENT_CURRENT('test1')
 

結果又不是我們想要的了!

再看看IDENT_CURRENT(Tablename) 的定義:IDENT_CURRENT(Tablename)

是返回指定表的最后標識值。

到這里,是該亮出答案的時候了,我們可以使用下面的代碼:

 

代碼六:
insert into test1 (content)
values ('solorez3')

SELECT scope_identity()
 

這時,我們無論是添加觸發器還是運行并行插入,得到的始終是當前事務的標識值。

scope_identity()的定義:scope_identity()

關鍵詞:插入、標識值

分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站