科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道解决SQL Server最大流水号的两个好方法

解决SQL Server最大流水号的两个好方法

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文将为大家介绍怎样才能解决SQL Server 2000 最大流水号的问题。

作者:赛迪网 yashi 来源:天新网 2008年4月25日

关键字: 数据库 Mssql SQL SQL Server

  • 评论
  • 分享微博
  • 分享邮件

问:请问怎样才能解决SQL Server 2000 最大流水号的问题?

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

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

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

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

create index idx_trade_id on tradeinfo(trade_id)

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

declare @mytradeid int 

set @mytradeid=0

begin transaction 

   insert into tradeinfo values(getdata(),"test")

  select @mytradeid = Scope_identite()

commit transaction 

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

select @mytradeid

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

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

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

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

create index idx_guid on max_trade_id(global_id)

declare @mytradeid int.,@myglobal_id uniqueidentifier

set @mytradeid = e-1

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

jselect @myglobal_id = newid()

insert into max_trade_id values(@myglobl_id)

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

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

selecgt @mytradeid

注:这种方法的好处是:它的并发性好,不会引起阻在塞,而且保证了insert语句肯定执行功能,这种方法的缺点是多一个guid。

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章