這是我的表設計:如何使用ADO.NET中的存儲過程在同一表中添加多行?
CREATE TABLE Member
(
Member_No UNIQUEIDENTIFIER DEFAULT NEWID() PRIMARY KEY,
Name VARCHAR(50) NOT NULL,
Email VARCHAR(50) NOT NULL,
Phone BIGINT NOT NULL,
Username VARCHAR(50) NOT NULL,
Password VARCHAR(50) NOT NULL
)
CREATE TABLE Toy
(
Toy_No UNIQUEIDENTIFIER DEFAULT NEWID() PRIMARY KEY,
Toy_Image VARBINARY(MAX) NOT NULL,
Toy_Name VARCHAR(50) NOT NULL,
Anime_Image VARBINARY(MAX) NOT NULL,
Anime_Name VARCHAR(50) NOT NULL,
Toy_Distributor_Image VARBINARY(MAX) NOT NULL,
Toy_Distributor VARCHAR(50) NOT NULL,
Price INTEGER NOT NULL,
Quantity INTEGER NOT NULL
)
CREATE TABLE Cart
(
Cart_No UNIQUEIDENTIFIER DEFAULT NEWID() PRIMARY KEY,
Toy_No UNIQUEIDENTIFIER NOT NULL,
Member_No UNIQUEIDENTIFIER NOT NULL,
Total_Quantity INTEGER,
Total_Price INTEGER,
CONSTRAINT FK_ToyNo
FOREIGN KEY(Toy_No) REFERENCES Toy(Toy_No),
CONSTRAINT FK_MemberNo
FOREIGN KEY(Member_No) REFERENCES Member(Member_No)
)
CREATE TABLE Toy_Purchase
(
Toy_Purchase_No UNIQUEIDENTIFIER DEFAULT NEWID() PRIMARY KEY,
Cart_No UNIQUEIDENTIFIER NOT NULL,
Toy_No UNIQUEIDENTIFIER NOT NULL,
Member_No UNIQUEIDENTIFIER NOT NULL,
Total_Quantity INTEGER NOT NULL,
Total_Price INTEGER NOT NULL,
Credit_Card_No BIGINT NOT NULL,
Purchase_Date DATETIME DEFAULT GETDATE() NOT NULL,
CONSTRAINT FK_CartNo
FOREIGN KEY(Cart_No) REFERENCES Cart(Cart_No),
CONSTRAINT FkToyNo
FOREIGN KEY(Toy_No) REFERENCES Toy(Toy_No),
CONSTRAINT FkMemberNo
FOREIGN KEY(Member_No) REFERENCES Member(Member_No)
)
這裏要注意的一件重要的事情是,通過存儲過程記錄在Total_Quantity
價值觀和Cart
表Total_Price
將Total_Quantity
和Toy_Purchase
表Total_Price
傳遞並插入所謂的PurchaseToys
,我將在最後展示。
這是我的存儲過程,名爲AddToCart
,我將選擇具有一個或多個數量的不同玩具,然後添加到購物車。
CREATE PROCEDURE AddToCart
@CartNo UNIQUEIDENTIFIER OUTPUT,
@ToyNo UNIQUEIDENTIFIER OUTPUT,
@MemberNo UNIQUEIDENTIFIER OUTPUT,
@TotalQuantity INTEGER,
@TotalPrice INTEGER OUTPUT
AS
BEGIN
SET @CartNo = NEWID()
SET @ToyNo = (SELECT Toy_No FROM Toy)
SET @MemberNo = (SELECT Member_No FROM Member)
SET @TotalPrice = @TotalQuantity*(SELECT Price FROM Toy WHERE [email protected])
INSERT INTO Cart(Cart_No, Toy_No, Member_No, Total_Quantity, Total_Price)
VALUES(@CartNo, @ToyNo, @MemberNo, @TotalQuantity, @TotalPrice)
END
這就是我所謂的DisplayCart
的存儲過程,它會顯示的,我已經加入到我的購物車購買前玩具項的列表。
CREATE PROCEDURE DisplayCart
AS
BEGIN
SELECT
Toy_Image, Toy_Name, Total_Quantity, Total_Price
FROM
Toy, Cart
WHERE
Toy.Toy_No = Cart.Toy_No
END
這是我的存儲過程,名爲PurchaseToys
。只有在我輸入我的信用卡號碼後,纔會執行此程序,然後單擊網站上的確認付款按鈕。
CREATE PROCEDURE PurchaseToys
@ToyPurhcaseNo UNIQUEIDENTIFIER OUTPUT,
@CartNo UNIQUEIDENTIFIER OUTPUT,
@ToyNo UNIQUEIDENTIFIER OUTPUT,
@MemberNo UNIQUEIDENTIFIER OUTPUT,
@TotalQuantity INTEGER OUTPUT,
@TotalPrice INTEGER OUTPUT,
@CreditCardNo BIGINT,
@PurchaseDate DATETIME OUTPUT
AS
BEGIN
SET @ToyPurhcaseNo = NEWID()
SET @CartNo = (SELECT Cart_No FROM Cart)
SET @ToyNo = (SELECT Toy_No FROM Toy)
SET @MemberNo = (SELECT Member_No FROM Member)
SET @TotalQuantity = (SELECT Total_Quantity FROM Cart WHERE Cart_No = @CartNo) -- I'm planning to pass the value of Total_Quantity in Toy_Purchase table from Total_Quantity of Cart table
SET @TotalPrice = (SELECT Total_Price FROM Cart WHERE Cart_No = @CartNo) -- I'm planning to pass the value of Total_Price in Toy_Purchase table from Total_Price of Cart table
SET @PurchaseDate = GETDATE()
INSERT INTO Toy_Purchase (Toy_Purchase_No, Cart_No, Toy_No, Member_No, Total_Quantity, Total_Price, Credit_Card_No, Purchase_Date)
VALUES (@ToyPurhcaseNo, @CartNo, @ToyNo, @MemberNo, @TotalQuantity, @TotalPrice, @CreditCardNo, @PurchaseDate)
UPDATE Toy
SET Quantity = Quantity - Total_Price
FROM Toy, Toy_Purchase
WHERE Toy.Toy_No = Toy_Purchase.Toy_No
END
一般來說,如果你看一下所謂的PurchaseToys
此存儲過程的邏輯,它會在Toy_Purchase表只插入一行和Toy
表Quantity
列值將減少爲只有單一的玩具。
但是,我想根據我選擇的玩具數量在Toy_Purchase
表中插入多行。例如,如果我購買了2種不同的玩具,則存儲過程應在Toy_Purchase
表中插入2行,Toy
表中的Quantity
列值將減少2個不同的玩具。
如果我購買了4種不同的玩具,存儲過程應該在Toy_Purchase
表中插入4行,玩具表中的Quantity
列值將針對4種不同的玩具減少。
那麼如何確保在Toy_Purchase
表中插入多行,並且通過ADO.NET中的存儲過程可以減少不同選定玩具數量的Quantity
列值?
[不良習慣踢:使用舊式JOIN](http://sqlblog.com/blogs/aaron_bertrand/archive/2009/10/08/bad-habits-to-kick-using-old-style- joins.aspx) - 在ANSI - ** 92 ** SQL標準(** 25年前的**)中,舊式*逗號分隔的表*樣式列表已替換爲* proper * ANSI'JOIN'語法它的使用是不鼓勵的 –