• 易迪拓培训,专注于微波、射频、天线设计工程师的培养
首页 > 无线通信 > 技术文章 > 解决SQL2000最大流水号的两个好方法

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

录入:edatop.com     点击:

问:请问怎样才能解决ms serer 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=0begin 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 uniqueidentifierset @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 _idselecgt @mytradeid

 

 

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

上一篇:集群存储管理的挑战与应对方法
下一篇:宽带接入发展需循序渐进

手机天线设计培训教程详情>>

手机天线设计培训教程 国内最全面、系统、专业的手机天线设计培训课程,没有之一;是您学习手机天线设计的最佳选择...【More..

射频和天线工程师培训课程详情>>

  网站地图