当前位置:  开发笔记 > 数据库 > 正文

如何获取SQL 2005和ASP中使用的下一个标识号?

如何解决《如何获取SQL2005和ASP中使用的下一个标识号?》经验,为你挑选了1个好方法。

我之前通过执行如下简单查询获得了Access中使用的下一个可用自动编号:

SELECT RecordNumber, Info FROM myTABLE WHERE 0=1

这样我就可以创建一个变量来保存currentRecord,它将使用与我更新行时Access将要使用的相同的自动编号

rs.AddNew
currentRecord = rs("RecordNumber")

rsInfo = "SomeFormData" & currentRecord
rs.Update
rs.Close

现在这用于MS Access,但在SQL 2005中,我没有收回新记录创建的Identity."SomeFormData"已正确插入,SQL中的RecordNumber字段已填入新的自动编号,但我的变量中没有RecordNumber,我需要它继续填写相关表格,将数据保存到相关表格并需要保存currentRecord号码.

问题是,有没有办法在做一个新插入时获得这个唯一的数字?



1> P Daddy..:

IDENT_CURRENT('tableName')(包括单引号)返回给定表的标识的当前值.此值应该是表中使用的最后分配的标识值.换句话说,除非该行已被删除,否则表中已有一行具有此标识值.将在下一次分配的标识值INSERTIDENT_CURRENT('tableName') + IDENT_INCR('tableName').

不过,我不建议依赖于此.如果您以这种方式预先确定下一个标识值,那么您最终会遇到另一个进程使得插入实际上在您之前获取该ID的情况,因此您的进程最终使用错误的ID值.

最好先插入插件(即使你还没有所有数据),并使用它SCOPE_IDENTITY()来获得实际的ID.

你可能想知道为什么SCOPE_IDENTITY()比这更好IDENT_CURRENT('tableName').顾名思义,前者将为您提供在当前范围内分配的最新身份值(您的批次,存储过程,等等),而后者将为您提供由任何人分配在桌面上的最新身份.即使你可能IDENT_CURRENT在'之后立即打电话INSERT,但仍有可能在其他人INSERT之间发生,并且IDENT_CURRENT会给你由他们的插入而不是你插入产生的身份价值,而SCOPE_IDENTITY总是会给你你的.

编辑:

值得一提的SCOPE_IDENTITY()是,与同样功能相比,它更受青睐@@IDENTITY.虽然两者都返回当前批次中指定的最新标识值,但@@IDENTITY会受到触发器中发生的插入的影响; SCOPE_IDENTITY()不是.

推荐阅读
可爱的天使keven_464
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有