欢迎光临
我们一直在努力

如何取得刚刚插入sql server 自增长的id值?-ASP教程,数据库相关

建站超值云服务器,限时71元/月

对于sql server 2000来说,它提供了两个全新的函数(ident_current,scope_identity),并且改进了@@identity的不足.当你插入新记录后,可以调用函数:

print ident_current(table) 这将获得新的identity值,不管数据库中是不是有记录添加(这就避免了@@identity的连接限制)

或者:print scope_identity() 这将获得在当前存储过程,触发器等其他程序创建的最新记录的identity值.

而全局变量@@identity有一个问题,当对一张表执行insert时,如果该表有触发器程序在执行插入操作,然后,接着在另一张表中插入记录,这样返回@@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

%>

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 如何取得刚刚插入sql server 自增长的id值?-ASP教程,数据库相关
分享到: 更多 (0)