触发器(trigger) 日期+流水=编号

create table tb(colID int identity,status int,ID nvarchar(14))
go

create trigger test on tb
for insert,update
as
begin
  if update(status)
  begin
    declare @status int,@colID int
    select @status = status,@colID = colID from inserted
    if @status = 1
    begin
      declare @Nowdate nvarchar(8),@OtherDate nvarchar(8),@Num nchar(13),@ID int
      select @Nowdate = convert(char(8),getdate(),112),@OtherDate = '19990101',@ID = 0,@Num = ''
      select @OtherDate = substring(ID,1,8),@ID = right(ID,4) from tb where substring(ID,1,8) = @Nowdate
      if @OtherDate <> @Nowdate
        begin
        select @ID = 0
      end;
      select @Num = @Nowdate + right((10000 + @ID + 1),4)
      update tb set id = @Num where colID = @colID
    end;
  end;
end;
go

insert into tb(status) select 1

select * from tb
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值