如何获得刚插入数据库的记录的ID号?

时间:2009-09-10 11:33:00 

1.SQL Server

对于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 
%>

在ASP里还可以

<%
'假设上面更新完成
sql="select top 1 id from table where 发布者ID='发布者ID' order by 时间 desc"
'然后执行它就得到了
%>

标签:sql,server,自动编号,IDENTITY,SCOPE_IDENTITY,IDENT_CURRENT
0
投稿

猜你喜欢

  • 防止网上重复投票的方法

    2009-06-01 12:31:00
  • firefox与ie 的javascript区别

    2010-03-14 11:30:00
  • em与px的区别以及em特点和应用

    2008-11-11 12:03:00
  • Asp包含文件include动态包含方法(含变量)

    2010-01-14 20:12:00
  • asp使用模板生成静态页面方法详解

    2007-09-24 12:29:00
  • 保护Access 2000数据库的安全

    2008-10-23 13:55:00
  • HTML,CSS和JavaScript速查表

    2010-09-16 13:02:00
  • 关于利用:first-letter实现首字下沉的一些看法

    2010-04-20 17:19:00
  • 关于文件命名

    2009-09-18 16:29:00
  • 五个影响mysql性能的关键配置

    2010-08-08 09:13:00
  • 如何优化JavaScript脚本的性能

    2008-02-19 21:47:00
  • 科讯CMS编辑器会自动更改代码

    2008-12-12 13:00:00
  • 基于网格的网页设计概念及实际应用案例

    2010-03-30 14:59:00
  • Javascript优化(文件瘦身)

    2008-06-02 13:20:00
  • MySQL Order By Rand()效率

    2011-01-04 19:34:00
  • 创建IE各版本专属CSS方法

    2007-09-27 12:16:00
  • asp实现将人民币数字改为大写

    2008-05-21 14:08:00
  • 有啊在设计上相对淘宝的优势

    2009-05-22 12:28:00
  • 实例讲解实现SQL下的字符串拆分具体方法

    2008-12-09 14:55:00
  • 定义列表: DL DT DD

    2009-05-06 13:08:00
  • asp之家 网络编程 m.aspxhome.com