SQLServer存储过程中事务的使用方法

本文为大家分享了SQLServer存储过程中事务的使用方法,具体代码如下

create proc usp_Stock
@GoodsId int,
@Number int,
@StockPrice money,
@SupplierId int,
@EmpId int,
@StockUnit varchar(50),
@StockDate datetime,
@TotalMoney money ,
@ActMoney money ,
@baseId int,
@Description nvarchar(255)
as
declare @error int =0 –事务中操作的错误记录
–开启事务
begin transaction
–实现进货信息的添加
insert into StockInfo values(@GoodsId, @Number, @StockPrice, @SupplierId, @EmpId, @StockUnit, @StockDate, @TotalMoney, @ActMoney,DEFAULT,@Description, @baseId)
set @error+=@@ERROR –记录有可能产生的错误号
–获取当前进货信息的标识列
–判断当前商品有没有进货记录
if exists (select * from dbo.InventoryInfo where goodid=@GoodsId) –说明记录存在,直接修改库存数量
begin
update dbo.InventoryInfo set GNumber=GNumber+@Number,TotalMoney+=@TotalMoney where goodid=@GoodsId
set @error+=@@ERROR –记录有可能产生的错误号
end
else –这个商品从来没有过进货记录,那么就应该添加新的存在信息
begin
declare @GWarningNum int –此商品的预警数量
–获取预警数量
set @GWarningNum=(select WaringNum from dbo.GoodsInfo where GId=@GoodsId)
insert into dbo.InventoryInfo values(@GoodsId,@Number,@baseId,@GWarningNum,@TotalMoney,’第一次进货’,default)
set @error+=@@ERROR –记录有可能产生的错误号
end
–判断事务的提交或者回滚
if(@error<>0)
begin
rollback transaction
return -1 –设置操作结果错误标识
end
else
begin
commit transaction
return 1 –操作成功的标识
end
go

希望本文所述对大家学习数据库操作有所帮助。

我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
沟通购买:QQ咨询 淘宝咨询 微信咨询 淘宝店铺
版权申明及联系
本站文章参考或来源于网络及部分网络投稿,如有侵权请联系站长。本站提供相关远程技术服务,有需要可联系QQ
数据运维技术 » SQLServer存储过程中事务的使用方法