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

作者:yashi 时间:2009-01-13 14:15:00 

解决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-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。

标签:
0
投稿

猜你喜欢

  • 利用XMLBean轻轻松松读写XML

    2008-09-04 11:25:00
  • JavaScript创始人Brendan Eich访谈录

    2008-09-16 12:01:00
  • SQL Server连接中经常出现的3个常见错误与解答

    2010-07-26 14:25:00
  • MYSQL数据库表设计与优化(二)

    2010-10-25 20:12:00
  • js放大缩小容器:仿动画

    2008-02-15 11:34:00
  • 另类读写:ACCESS中Field对象的标题属性

    2008-11-28 16:47:00
  • 用browsercam做用户登录后页面的兼容性测试

    2008-12-29 12:05:00
  • asp获取数据库中表名和字段名的代码

    2011-04-18 11:02:00
  • asp如何在线查询本地机的文件?

    2010-06-22 21:19:00
  • ASP日期格式化函数

    2010-08-08 19:18:00
  • oracle chm帮助文件下载

    2010-07-16 12:49:00
  • 如何从Notes中读取数据?

    2009-11-15 19:57:00
  • 从HTTP状态 301,302,200 来看页面跳转

    2007-09-26 13:46:00
  • XMLHTTP资料

    2008-09-05 17:20:00
  • SQL server高级应用 收藏版

    2012-10-07 11:04:06
  • 开发保留标准的浏览器功能的AJAX应用

    2008-02-03 14:03:00
  • 在MySQL中使用XML数据—数据格式化

    2009-12-29 10:26:00
  • 如何解决“cint和clng的溢出出错”问题?

    2009-12-03 20:21:00
  • ASP下批量删除数据的两种方法

    2011-02-05 11:01:00
  • Oracle数据库与SQL Server数据库镜像对比

    2009-04-11 16:24:00
  • asp之家 网络编程 m.aspxhome.com