日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

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

系統 2744 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條評論
主站蜘蛛池模板: 博野县| 砀山县| 绵阳市| 乐都县| 阳高县| 大理市| 禄丰县| 儋州市| 黑龙江省| 宝山区| 辽宁省| 南部县| 塔河县| 西峡县| 屯门区| 天水市| 湘西| 三穗县| 蒲江县| 常宁市| 朝阳市| 大埔县| 玉屏| 肇州县| 夏河县| 分宜县| 洱源县| 河东区| 和龙市| 札达县| 民权县| 修武县| 门头沟区| 忻州市| 开平市| 黎川县| 元江| 定远县| 隆化县| 湘潭县| 酉阳|