MySQL 存储过程 Case 语句语法错误 - 续

标签 mysql if-statement stored-procedures syntax-error

程序包含语法错误。请帮我找出错误。 mySQL Workbench 说这有 8 个错误,不能应用于数据库。我已经发布了这个问题。人们告诉我将 CASE 语句更改为 IF。即使更改后,错误仍然存​​在。我不知道如何将这篇文章嵌套在原始问题下。实际帖子发布在这个link . 修改后的语法已按要求发布@Caius Jard

CREATE PROCEDURE `calculate_amount` (in IN_book_id INT,  in IN_qty INT )
BEGIN
-- declare
DECLARE m_prdct VARCHAR(10);
DECLARE m_cust_id INT(5);

-- select into
SELECT 
    Product
FROM
    Bookings
WHERE
    Book_id = IN_book_id INTO m_prdct;

SELECT 
    Cust_id
FROM
    Bookings
WHERE
    Book_id = IN_book_id INTO m_cust_id;

-- conditionals & action
IF (m_prdct = '20ltr') THEN
INSERT INTO Amount(Cust_id,Book_id,Can,300ml,500ml,1lit,2lit) VALUES(m_cust_id,IN_book_id,(SELECT Rate.Can*Bookings.Qty FROM Rate,Bookings WHERE Bookings.Book_id=IN_book_id),0,0,0,0); 

ELSEIF (m_prdct = '300ml') THEN
INSERT INTO Amount(Cust_id,Book_id,Can,300ml,500ml,1lit,2lit) VALUES(m_cust_id,IN_book_id,0,(SELECT Rate.300ml*Bookings.Qty FROM Rate,Bookings WHERE Bookings.Book_id=IN_book_id),0,0,0);

ELSEIF (m_prdct = '500ml') THEN 
INSERT INTO Amount(Cust_id,Book_id,Can,300ml,500ml,1lit,2lit) VALUES(m_cust_id,IN_book_id,0,0,(SELECT Rate.500ml*Bookings.Qty FROM Rate,Bookings WHERE Bookings.Book_id=IN_book_id),0,0); 

ELSEIF (m_prdct = '1ltr') THEN 
INSERT INTO Amount(Cust_id,Book_id,Can,300ml,500ml,1lit,2lit) VALUES(m_cust_id,IN_book_id,0,0,0,(SELECT Rate.1lit*Bookings.Qty FROM Rate,Bookings WHERE Bookings.Book_id=IN_book_id),0); 

ELSE 
INSERT INTO Amount(Cust_id,Book_id,Can,300ml,500ml,1lit,2lit) VALUES(m_cust_id,IN_book_id,0,0,0,0,(SELECT Rate.2lit*Bookings.Qty FROM Rate,Bookings WHERE Bookings.Book_id=IN_book_id)); 
-- end
END IF;
END

最佳答案

您需要引用以数字开头的标识符:

INSERT INTO Amount(Cust_id,Book_id,Can,`300ml`,`500ml`,`1lit`,`2lit`) ... 

关于MySQL 存储过程 Case 语句语法错误 - 续,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52233963/

相关文章:

javascript - if else 语句中的多个 if else - 模拟滚动

Python:检查一个元素是否在另外两个元素之间

c# - 在函数内执行存储过程而不等待返回

mysql - 如何选择年龄范围内的人

php - Laravel - 用户外键导致尝试获取非对象的属性

php - 查询我们没有售出任何东西的缺失月份?

python - 无法安装 MySQL 连接器/Python?

java - 如果两个复选框都被选中怎么办?

c# - .NET Core (NET Standard 2.1) 中 DataTable/DataSet 的替换

mysql - 如何在 MySQL 过程中选择参数作为表列?