SQL存储过程Error code is 1064,详细解决方案

错误: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;

以上为本人在工作中遇见的问题,解决方案真实有效!

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值