DIY编程器网

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 877|回复: 0
打印 上一主题 下一主题

[待整理] 解决SQL2000最大流水号的两个好方法

[复制链接]
跳转到指定楼层
楼主
发表于 2014-10-13 15:12:06 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
问:请问怎样才能解决ms serer 2000 最大流水号的问题?

答:我可以介绍两种方法给你:

方法1:使用SCOPE_IDENTITY取得刚刚插入的最大流水号

           
  1. /*建立traddeinfo表各相关索引,注意Trade_id字段必段是identity型*/

  2. create table Tradeinfo(Trade_id int identity(1,1),Tdtime datetime Tdname varchar(20))

  3. create index idx_trade_id on tradeinfo(trade_id)

  4. /*使用scope_identity()中断函数,取得当前脚本范围内最后insert进去的identity值*/

  5. declare @mytradeid int

  6. set @mytradeid=0

  7. begin transaction

  8.    insert into tradeinfo values(getdata(),'test')

  9.   select @mytradeid = Scope_identite()

  10. commit transaction

  11. /*把@mytradeid 变量中存放的流水号显示出来*/

  12. select @mytradeid
复制代码
           


方案2:结合uniqueidentifier和identity取得最大流水号

           
  1. /*创建辅助表 id字段是identity类型,global_id是gudi类型*/

  2. cretate table max_tradeid(id int identity(1,1),global_id uniqueidenfier)

  3. /*创建索引以加速后面的select 语句*/

  4. create index idx_guid on max_trade_id(global_id)

  5. declare @mytradeid int.,@myglobal_id uniqueidentifier

  6. set @mytradeid = e-1

  7. /*利用newid ()函数取得一个全局叭一guid .由于guid的特性,不用别的并发进程会产生同样的guid值 */

  8. jselect @myglobal_id = newid()

  9. insert into max_trade_id values(@myglobl_id)

  10. /*使用全局唯一guid得到刚刚插入的id值*/

  11. select @mytradeid = id from max_trade_id  where globl_id =@myglobal _id

  12. selecgt @mytradeid
复制代码
           


注:这种方法的好处是:它的并发性好,不会引起阻在塞,而且保证了insert语句肯定执行成功,这种方法的缺点是多一个guid。
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|文字版|手机版|DIY编程器网 ( 桂ICP备14005565号-1 )

GMT+8, 2024-9-27 15:26 , 耗时 0.095836 秒, 18 个查询请求 , Gzip 开启.

各位嘉宾言论仅代表个人观点,非属DIY编程器网立场。

桂公网安备 45031202000115号

DIY编程器群(超员):41210778 DIY编程器

DIY编程器群1(满员):3044634 DIY编程器1

diy编程器群2:551025008 diy编程器群2

QQ:28000622;Email:libyoufer@sina.com

本站由桂林市临桂区技兴电子商务经营部独家赞助。旨在技术交流,请自觉遵守国家法律法规,一旦发现将做封号删号处理。

快速回复 返回顶部 返回列表