唐山网站建设

设为主页 加入收藏 繁體中文

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

核心提示:解决SQLServer最大流水号的两个好方法 ...

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

问:请问怎样才能解决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=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⑴

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

jselect @myglobal_id = newid()

insert into max_trade_id values(@myglobl_id)

/*使用全局唯1guid得到刚刚插进的id值*/

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

selecgt @mytradeid
 
注:这类方法的好处是:它的并发性好,不会引发阻在塞,而且保证了insert语句肯定履行成功,这类方法的缺点是多1个guid。

唐山网站建设www.fw8.net


TAG:方法,函数,语句,字段,全局
评论加载中...
内容:
评论者: 验证码: