ストアド プロシージャの作成が成功した後で、ストアド プロシージャを変更しようとしました。
DELIMITER $$
ALTER PROCEDURE `purchaseItem`(
IN productID INT,
IN quantity INT,
IN memID INT,
OUT stat INT)
BEGIN
DECLARE qnty INT;
DECLARE price decimal(10,2);
DECLARE description VARCHAR(500);
SET qnty = (SELECT p_Unit FROM product WHERE p_ID = productID);
IF qnty >= quantity && qnty != 0 THEN
SELECT p_Price INTO price FROM product WHERE p_ID = productID;
SELECT p_Desc INTO description FROM product WHERE p_ID = productID;
INSERT INTO purchase VALUES
(NULL, productID, quantity, price, description , memID, 0, NULL);
UPDATE product
SET p_Unit = (qnty - quantity)
WHERE p_ID = productID;
SET stat = 0;
ELSE
SET stat = 1;
END IF;
END$$
DELIMITER ;
しかし、SP を変更しようとすると、次のエラーが発生しました。
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '( IN productID INT, IN quantity INT, IN memID INT, ' at line 1
誰かが私が間違っているところを指摘してもらえますか。ありがとう!