Chinaunix首页 | 论坛 | 博客
  • 博客访问: 898600
  • 博文数量: 1812
  • 博客积分: 90800
  • 博客等级: 元帅
  • 技术积分: 22390
  • 用 户 组: 普通用户
  • 注册时间: 2008-05-03 18:35
文章分类

全部博文(1812)

文章存档

2008年(1812)

我的朋友

分类:

2008-05-03 18:40:02

一起学习

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

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

一起学习 解决SQL Server最大流水号的两个好方法解决SQL Server最大流水号的两个好方法解决SQL Server最大流水号的两个好方法解决SQL Server最大流水号的两个好方法解决SQL Server最大流水号的两个好方法解决SQL Server最大流水号的两个好方法解决SQL Server最大流水号的两个好方法解决SQL Server最大流水号的两个好方法解决SQL Server最大流水号的两个好方法解决SQL Server最大流水号的两个好方法解决SQL Server最大流水号的两个好方法解决SQL Server最大流水号的两个好方法
阅读(710) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~