ORACLE里的sequence在SQL Server里怎么实现?

lzjever 2005-02-24 12:31:11
取出增长的唯一值,而且这个值并不是写入数据库后才取出的(identity)。 他将返回给客户端, 处理完成之后做为本次操作的主键写入数据库。 原来数据库采用 ORACLE, 用sequence很容易解决, 现在移植到SQL Server上如何解决?
...全文
437 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
lzjever 2005-02-28
  • 打赏
  • 举报
回复
前台判断也是不行的。因为这个是移植的工程, 客户端是不能做改变的, 只有服务器端更改。
唉~ 继续顶这个问题。
---涛声依旧--- 2005-02-25
  • 打赏
  • 举报
回复
我一般在前台控制﹐每次insert前判斷該遞增的值是否存在﹔
在后台可以建一個遞增的函數﹐并將此函數作為遞增字段的默認值
自定义一个表,存储当前值也可以﹐隨你選擇了
---涛声依旧--- 2005-02-25
  • 打赏
  • 举报
回复
我一般在前台控制﹐每次insert前判斷該遞增的值是否存在﹔
在后台可以建一個遞增的函數﹐并將此函數作為遞增字段的默認值
自定义一个表,存储当前值也可以﹐隨你選擇了
lzjever 2005-02-24
  • 打赏
  • 举报
回复
PS:用的技术是 ATL + ADO, 而且这个唯一值必须是递增的整数, 不能用GUID
lzjever 2005-02-24
  • 打赏
  • 举报
回复
原子性怎么保证? 多用户并发的时候是不是还是可能会取到 相同的值呢?
jinjazz 2005-02-24
  • 打赏
  • 举报
回复
那你自定义一个表,存储当前值
lzjever 2005-02-24
  • 打赏
  • 举报
回复
多谢邹建大哥, 不过我想您可能没有明白我的意思. 现在表里并没有设identity的字段.
而且就算能够取到下一个递增的值, 也还有问题, 因为这个值并没有马上写入到数据库里去.这样可能某个用户取了一个值以后, 另一个用户取到相同的值. 我的目的就是每次取值, 都确保是不一样的, 而且这个值是递增的. 继续求教....
zjcxc 元老 2005-02-24
  • 打赏
  • 举报
回复
IDENT_INCR
返回增量值(返回形式为 numeric(@@MAXPRECISION,0)),该值是在带有标识列的表或视图中创建标识列时指定的。

语法
IDENT_INCR ( 'table_or_view' )

参数
table_or_view

一个表达式,用来指定表或视图以检查有效的标识增量值。table_or_view 可以是带有引号的字符串常量,也可以是变量、函数或列名。table_or_view 的数据类型为 char、nchar、varchar 或 nvarchar。



IDENT_CURRENT
返回为任何会话和任何作用域中的指定表最后生成的标识值。

语法
IDENT_CURRENT('table_name')

参数
table_name

是将要返回其标识值的表的名称。table_name 的数据类型为 varchar,没有默认值。

返回类型
sql_variant

注释
IDENT_CURRENT 类似于 Microsoft® SQL Server™ 2000 标识函数 SCOPE_IDENTITY 和 @@IDENTITY。这三个函数都返回最后生成的标识值。但是,它们在定义"最后"的作用域和会话上不同。

IDENT_CURRENT 返回为任何会话和任何作用域中的特定表最后生成的标识值。


@@IDENTITY 返回为当前会话的所有作用域中的任何表最后生成的标识值。


SCOPE_IDENTITY 返回为当前会话和当前作用域中的任何表最后生成的标识值。
zjcxc 元老 2005-02-24
  • 打赏
  • 举报
回复
--用下面的语句,jobs是你要查询的表

select IDENT_CURRENT('jobs')+IDENT_INCR('jobs')

34,593

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧