|
![]() |
名片设计 CorelDRAW Illustrator AuotoCAD Painter 其他软件 Photoshop Fireworks Flash |
|
对于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 %> 返回类别: 教程 上一教程: RECORDCOUNT=-1问题 下一教程: JAVASCRIPT在ASP中实现掩码文本框 您可以阅读与"如何取得刚刚插入SQL SERVER自增长的ID值"相关的教程: · 如何得到上一次插入记录后自动产生的ID · ADO如何取得数据库中表的字段信息之二 · 如何用ASP把SQL SERVER数据转化为EXECL文件 · 如何取得所有的SESSION变量 · SQL Server如何解决加密问题? |
![]() ![]() |
快精灵印艺坊 版权所有 |
首页![]() ![]() ![]() ![]() ![]() ![]() ![]() |