對于sql server 2000來說,它提供了兩個全新的函數(shù)(ident_current,scope_identity),并且改進(jìn)了@@identity的不足.當(dāng)你插入新記錄后,可以調(diào)用函數(shù):
print ident_current(table) 這將獲得新的identity值,不管數(shù)據(jù)庫中是不是有記錄添加(這就避免了@@identity的連接限制)
或者:print scope_identity() 這將獲得在當(dāng)前存儲過程,觸發(fā)器等其他程序創(chuàng)建的最新記錄的identity值.
而全局變量@@identity有一個問題,當(dāng)對一張表執(zhí)行insert時,如果該表有觸發(fā)器程序在執(zhí)行插入操作,然后,接著在另一張表中插入記錄,這樣返回@@identity值就是第二張表的identity值。
如果你用的不是sql server 2000,你最好一個簡單的存儲過程來解決這個問題。
create procedure myproc
@param1 int
as
begin
set nocount on
insert into sometable
(
intfield
)
values
(
@param1
)
set nocount off
select newid = @@identity
end
在asp中你可以這樣做:
<%
fakevalue = 5
set conn = server.createobject("adodb.connection")
conn.open "<conn string>"
set rs = conn.execute("exec myproc @param1=" & fakevalue)
response.write "new id was " & rs(0)
rs.close: set rs = nothing
conn.close: set conn = nothing
%>
該評論在 2010/12/13 14:16:19 編輯過