zoukankan      html  css  js  c++  java
  • 解决SQLServer最大流水号的两个好方法

    方法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。

  • 相关阅读:
    同一子网建立ssh通道,映射到本地
    机器学习线性模型-自定义各个模块阶段
    MATLAB中图像处理的函数
    基于鱼皮肤的鱼个体识别(1)
    防骗指南-东南亚绑架,诈骗,菠菜
    防骗指南-识别传销
    防骗指南-套路贷以及肉偿
    防骗指南-套路贷如何识别
    Opencv 特征提取与检测-Haar特征
    1. QCamera2基础组件——cam_semaphore
  • 原文地址:https://www.cnblogs.com/hanmos/p/1997792.html
Copyright © 2011-2022 走看看