社区
MS-SQL Server
帖子详情
ORACLE里的sequence在SQL Server里怎么实现?
lzjever
2005-02-24 12:31:11
取出增长的唯一值,而且这个值并不是写入数据库后才取出的(identity)。 他将返回给客户端, 处理完成之后做为本次操作的主键写入数据库。 原来数据库采用 ORACLE, 用sequence很容易解决, 现在移植到SQL Server上如何解决?
...全文
437
9
打赏
收藏
ORACLE里的sequence在SQL Server里怎么实现?
取出增长的唯一值,而且这个值并不是写入数据库后才取出的(identity)。 他将返回给客户端, 处理完成之后做为本次操作的主键写入数据库。 原来数据库采用 ORACLE, 用sequence很容易解决, 现在移植到SQL Server上如何解决?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用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')
MS-SQL Server
34,593
社区成员
254,590
社区内容
发帖
与我相关
我的任务
MS-SQL Server
MS-SQL Server相关内容讨论专区
复制链接
扫一扫
分享
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章