错误:Error code is 1064\n\nYou have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near” at line 8″.(大概意思就是在你执行存储过程中sql语句处报错。)
报错原因:因为部分软件对分隔符(;)识别上有歧义,所以必须先定义一个标准的分隔符例如:
DELIMITER \ (标准分割符可以定义自己喜欢的符合例如:DELIMITER $$)
举例说明:
案例1(测试一下,存储过程是否起作用)
# 判断存储名test_select是否存,如果存在直接删除,否则执行存储过程会是写在缓存中的内容!
DROP PROCEDURE IF EXISTS test_select;
DELIMITER // # 定义标准分隔符
CREATE PROCEDURE test_select ()
BEGIN
SELECT '测试一下';
END //
CALL test_select(); #调用存储过程并执行
案例2
# 判断存储名test_select是否存,如果存在直接删除,否则执行存储过程会是写在缓存中的内容!
DROP PROCEDURE IF EXISTS test_select;
DELIMITER // # 定义标准分隔符
CREATE PROCEDURE test_select ()
BEGIN
SELECT COUNT(*) FROM TR_USR_PYE WHERE USR_ID='000000970804';
END // # 在程序执行结束的时候使用标识,程序执行完成
CALL test_select();
注意:执行的时候需要选中定义的分隔符,不然还是会报错Error code is 1064
显示已创建的所有存储过程信息
SHOW PROCEDURE status;
以上为本人在工作中遇见的问题,解决方案真实有效!