数据库存储过程多用户同时冲突问题解决构思

本文介绍如何使用SQL编写函数自动生成流水号,并将数据存储到指定的临时表中,包括函数的实现、调用方法以及数据存储过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 写个函数自动生成流水号

--得到最新编号的函数
create function f_newid()
returns char(7)   --编号位数固定,用char的检索效率高于varchar
as
begin
    declare @re char(7)
    select @re=max(BHID) from 表(tablockx) --加表级锁
    return(
       case when @re is null then 'BH00001'
           else 'BH'+right('0000'+cast(cast(right(@re,5) as int)+1 as varchar),5)
       end)
end
go

函数调用方法:

如果是标值量函数:
select dbo.函数名(参数们)

如果是表值函数:
select * from 函数名(参数们)

2 将流水号插入临时表#code

3 将数据存储到流水号命名的临时表#salebase_流水号。

4 drop 所有临时表

 

转载于:https://www.cnblogs.com/CandiceW/p/4459727.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值