gpt4 book ai didi

mysql - 创建过程 mysql CRUD 时出错

转载 作者:行者123 更新时间:2023-11-29 05:03:42 24 4
gpt4 key购买 nike

我一直在第 9 行收到语法错误

CREATE PROCEDURE `ItemsAddOrEdit`(
_itm_id INT,
_itm_name VARCHAR(255),
_itm_price FLOAT(8,2)
)
BEGIN
IF _itm_id = 0 THEN
INSERT INTO items (itm_name, itm_price)
VALUES (_itm_name, _itm_price);
ELSE
UPDATE items
SET
itm_name = _itm_name,
itm_price = _itm_price
WHERE itm_id = _itm_id;
END IF;
END

变量是问题所在吗?我检查了表格,看看我是否把名字弄乱了,但对我来说一切都很好。这是表格代码

CREATE TABLE `items` (
`itm_id` INT(255) NOT NULL AUTO_INCREMENT,
`itm_name` VARCHAR(255) NOT NULL,
`itm_price` FLOAT(8,2) NOT NULL,
PRIMARY KEY (`itm_id`),
UNIQUE INDEX `itm_name` (`itm_name`)
)

最佳答案

  • 您需要将 Delimiter 重新定义为其他内容,例如:$$。这允许解析器忽略 ;(因此不会在到达 ; 时执行语句)。
  • 此外,作为一种好的做法,请始终使用 DROP PROCEDURE IF EXISTS,以避免在同名过程已存在的情况下失败。
  • 最后,将分隔符重新定义回;

尝试以下操作:

DELIMITER $$

DROP PROCEDURE IF EXISTS `ItemsAddOrEdit` $$

CREATE PROCEDURE `ItemsAddOrEdit`(
_itm_id INT,
_itm_name VARCHAR(255),
_itm_price FLOAT(8,2)
)
BEGIN
IF _itm_id = 0 THEN
INSERT INTO items (itm_name, itm_price)
VALUES (_itm_name, _itm_price);
ELSE
UPDATE items
SET
itm_name = _itm_name,
itm_price = _itm_price
WHERE itm_id = _itm_id;
END IF;
END $$

DELIMITER ;

关于mysql - 创建过程 mysql CRUD 时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52671758/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com