SQLServer存储过程中事务的方法
旨在介绍SQLServer存储过程中事务的使用方法,通过一段简洁明了的代码示例,帮助大家更好地理解和掌握这一技能。对于对数据库操作感兴趣的朋友们来说,具有重要的参考价值。
下面是一个关于SQLServer存储过程的示例代码,该过程名为usp_Stock,用于处理库存进货事务。
```sql
CREATE PROCEDURE 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
BEGIN
-- 声明变量记录事务中的错误
DECLARE @error INT = 0;
-- 开始事务
BEGIN TRANSACTION;
-- 添加进货信息
INSERT INTO StockInfo (GoodsId, Number, StockPrice, SupplierId, EmpId, StockUnit, StockDate, TotalMoney, ActMoney, Description)
VALUES (@GoodsId, @Number, @StockPrice, @SupplierId, @EmpId, @StockUnit, @StockDate, @TotalMoney, @ActMoney);
SET @error += @@ERROR; -- 记录可能的错误号
-- 检查当前商品的进货记录
IF EXISTS (SELECT FROM dbo.InventoryInfo WHERE goodid = @GoodsId)
BEGIN
-- 更新库存数量及总金额
UPDATE dbo.InventoryInfo SET GNumber = GNumber + @Number, TotalMoney = TotalMoney + @TotalMoney WHERE goodid = @GoodsId;
SET @error += @@ERROR; -- 记录可能的错误号
END
ELSE
BEGIN
DECLARE @GWarningNum INT; -- 商品预警数量变量
seo推广
- 2014年Godaddy帐号注册教程、Push接收、解析、DNS修
- Win10开启旧版托盘时钟让其符合以往的习惯
- 湖南3家微信公众账号传播恶性谣言被关停
- 想使用PE里没有的程序如何把程序打包进WinPE中
- win10预览版10041官方下载地址 win10预览版10041下载
- 本本加内存后为何还变慢了?
- Ecshop后台拿shell方法总结
- AI简单绘制超美的渐变试管图片教程
- Dreamweaver CS6怎么使用项目列表-
- 夜班配置 夜班最低配置及要求
- 客户端安装过程中提示RegCreateKeyEx失败.错误码5
- WinCfg32.exe - WinCfg32是什么进程
- VC7SecS.exe是什么进程.有什么用
- css3 条纹化和透明化表格Firefox下测试成功
- MirOS BSD Korn Shell本地权限提升漏洞
- 上网本在播放视频时,音频出现停顿现象是什么原