如何获得刚插入数据库的记录的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
投稿

猜你喜欢

  • Python中每次处理一个字符的5种方法

    2023-09-26 02:49:13
  • python爬取代理ip的示例

    2022-01-20 11:41:12
  • python使用sessions模拟登录淘宝的方式

    2023-01-09 12:05:25
  • Python设计模式之观察者模式简单示例

    2023-07-12 04:36:06
  • Python采集某评论区内容的实现示例

    2023-02-28 15:07:10
  • 使用 JSON 进行数据传输

    2008-06-15 07:12:00
  • innerHTML在Mozilla Firefox和Opera下执行的一个特例情况。

    2023-09-16 11:23:46
  • zen coding的dreamweaver插件安装教程

    2010-01-12 13:30:00
  • SQL基础语句总结

    2011-03-11 14:54:00
  • SpringBoot调用python接口的实现步骤

    2022-01-24 22:41:57
  • python数据可视化使用pyfinance分析证券收益示例详解

    2022-05-24 06:59:13
  • XMLHTTP自动判断远程网页字符编码

    2007-12-28 13:41:00
  • Vue侦测相关api的实现方法

    2024-05-09 09:52:46
  • Python 写入训练日志文件并控制台输出解析

    2021-10-11 01:27:10
  • 详解JS如何判断对象上是否存在某个属性

    2024-04-16 09:49:28
  • 实用又漂亮的BootstrapValidator表单验证插件

    2024-05-09 10:39:52
  • python自动截取需要区域,进行图像识别的方法

    2021-05-14 11:04:42
  • 基于python爬取链家二手房信息代码示例

    2022-09-01 18:36:25
  • VScode连接远程服务器上的jupyter notebook的实现

    2022-02-19 17:09:51
  • 表单特殊输入js验证

    2008-03-26 12:01:00
  • asp之家 网络编程 m.aspxhome.com