亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

存儲過程之銷售同時修改倉庫

系統 2546 0


--? 建立倉庫表
IF(EXISTS(SELECT name FROM SYSOBJECTS WHERE NAME='倉庫' AND TYPE='U'))
?DROP TABLE 倉庫
GO

CREATE TABLE 倉庫
(
?玩具號 NVARCHAR(20) PRIMARY KEY,
?庫存 INT,
?平均單價 FLOAT(8)
)
GO

-- 向倉庫表中添加數據
INSERT 倉庫 VALUES('12-1',100,50)
INSERT 倉庫 VALUES('12-2',80,80)
INSERT 倉庫 VALUES('12-3',60,100)
GO

-- 創建銷售表
IF(EXISTS(SELECT NAME FROM SYSOBJECTS WHERE NAME='銷售' AND TYPE='U'))
?DROP TABLE 銷售
GO

CREATE TABLE 銷售
(?
?SqlID INT IDENTITY(1,1) PRIMARY KEY,
?玩具號 NVARCHAR(20),
?數量 INT,
?銷售單價 FLOAT(8)
)
GO

-- 創建存儲過程
IF(EXISTS(SELECT NAME FROM SYSOBJECTS WHERE NAME='SP_INSERTSALE' AND TYPE='P'))
?DROP PROC SP_INSERTSALE
GO
CREATE PROC SP_INSERTSALE
?@toyID nvarchar(20),
?@toyquantity int,
?@toyprice float(8)
AS
DECLARE @tempquantity int?--臨時變量,用于保存庫存?
DECLARE @tempprice float(8)?--臨時變量,用于保存原始平均單價
DECLARE @tempSum float(8)?--臨時變量,用于保存原始總成本
DECLARE @insError int??--此變量用于保存插入時返回的@@ERROR值
DECLARE @upError int??--此變量用于保存更新時返回的@@ERROR值
BEGIN
?IF(EXISTS(SELECT * FROM 倉庫 WHERE 玩具號 =@toyid ))
??BEGIN?
???SELECT @tempprice=平均單價 FROM 倉庫 WHERE 玩具號 =@Toyid
???SELECT @tempquantity=庫存 FROM 倉庫 WHERE 玩具號 =@Toyid
???IF @tempquantity>=@toyquantity
????BEGIN
?????BEGIN TRAN
?????INSERT 銷售(玩具號,數量,銷售單價) VALUES(@toyid,@toyquantity,@toyprice)
?????SELECT @InsError=@@ERROR
?????SELECT @tempSum=@tempquantity*@tempprice-@toyquantity*@toyprice
?????SELECT @tempprice=@tempSum/(@tempquantity-@toyquantity) FROM 銷售 WHERE 玩具號 =@toyid
?????UPDATE 倉庫 SET 庫存 =@tempquantity-@toyquantity ,平均單價 =@tempprice WHERE 玩具號 =@toyid
?????SELECT @upError=@@Error
?????IF @InsError=0 AND @upError=0
??????BEGIN
???????COMMIT TRAN
???????PRINT '操作成功!'??
??????END
?????ELSE
??????BEGIN
???????ROLLBACK TRAN
???????PRINT '操作失敗!'?
??????END?
?????
????END
???ELSE
????PRINT '數量不夠!'
??END
?ELSE
???PRINT '沒有這樣的貨!'
END
GO

EXEC SP_INSERTSALE '12-3',120,20
GO
-- 數量不夠

EXEC SP_INSERTSALE '12-4',20,20
GO
-- 沒有這樣的貨

EXEC SP_INSERTSALE '12-1',20,55
GO

-- (所影響的行數為 1 行)
--
--
-- (所影響的行數為 1 行)
--
-- 操作成功
SELECT * FROM 倉庫
GO
SELECT * FROM 銷售
GO

存儲過程之銷售同時修改倉庫


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲国产精品第一区二区三区 | 美女嗯啊 | 亚洲国产精品久久久天堂麻豆 | 99精品视频在线观看免费播放 | 91视频第一页 | 日本欧美一二三区色视频 | 亚洲免费久久 | 欧美一级久久久久久久久大 | 亚洲骚片| 国产欧美一区二区三区免费看 | 精品久久久久国产免费 | 日本不卡高清 | 九九热精品视频在线观看 | 日本午夜www高清视频 | 亚洲国产精品67194成人 | 26uuu另类欧美亚洲日本 | 美女福利视频一区二区 | 午夜精品久久久久 | 亚洲成人综合网站 | 毛片91| 亚洲精品1区 | 久草在线视频精品 | 2046影院视频大全在线观看 | 三级性生活视频 | 免费观看欧美精品成人毛片能看的 | 激情综合色综合啪啪开心 | 成人免费视频视频在线不卡 | 亚洲欧美日韩高清一区二区三区 | 亚洲日本中文字幕在线2022 | 日本中文字幕有码 | 欧美一区二区三区久久久 | 高清中文字幕视频在线播 | 久久免费看视频 | 超级碰碰青草久热国产 | 国产亚洲精品91 | 天天射日日干 | 四虎1515hhwocw | 狠狠色噜噜狠狠狠狠2021天天 | 日本特黄特色aaa大片免费 | 国产免费一区二区在线看 | 国产免费人人看大香伊 |