发布网友 发布时间:2022-04-08 19:24
共2个回答
懂视网 时间:2022-04-08 23:45
insert into UserInformation
(Name,Pwd,Email) output inserted.Id values(‘小明‘,‘123‘,‘111‘)
除了主键,也可以输出别的字段,准确高效。
推荐使用第二种
如何准确高效的获取数据库新插入数据的主键id
标签:
热心网友 时间:2022-04-08 20:53
或者:PRINT SCOPE_IDENTITY() /'这将获得在当前存储过程,触发器等其他程序创建的最新记录的IDENTITY值. 而全局变量@@IDENTITY有一个问题,当对一张表执行insert时,如果该表有触发器程序在执行插入操作,然后,接着在另一张表中插入记录,这样返回@@IDENTITY值就是第二张表的IDENTITY值。 如果你用的不是SQL Server 2000,你最好一个简单的存储过程来解决这个问题。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 % 2.Access 对于Access,你可以用下面这样的方法: <% fakeValue = 5 set conn = Server.CreateObject(ADODB.Connection) conn.openconn.execute Insert into someTable(intField) values( & fakeValue & ) set rs = conn.execute(select MAX(ID) from someTable) response.write New ID was & rs(0) rs.close: set rs = nothing conn.close: set conn = nothing % 然而对于多人同时向数据库中添加数据,我们就要利用记录集的adOpenKeyset游标来防止出错。