mysql导入存储过程时declare报错的问题解决 在导入存储过程时经常遇见下列DECLARE报错的问题: ? Error Code : 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 ne

mysql导入存储过程时declare报错的问题解决

在导入存储过程时经常遇见下列DECLARE报错的问题:

?

Error Code : 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 '' at line 3

(0 ms taken)

?

有多少个DECLARE就会报多少次,然后后面就是取不到变量的报错。

?

这个原因是没有定义delimiter

?

如下的会报错:

CREATE PROCEDURE p8()?

BEGIN?

DECLARE a INT;?

DECLARE b INT;?

SET a = 5;?

SET b = 5;?

select pkid,name,userGroup_desc,parent_id,group_state from T_VSM_SECPOLICY_USERGROUP;?

END;

错误信息:

Error Code : 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 '' at line 3

(0 ms taken)

?

。。。。

?

添加了delimiter后就不报了

delimiter //

CREATE PROCEDURE p8() ?

BEGIN ?

DECLARE a INT; ?

DECLARE b INT; ?

SET a = 5; ?

SET b = 5; ?

declare cur0 cursor for select pkid from T_VSM_SECPOLICY_USERGROUP; ?--这里为什么报错?

END//

?

具体原因可以查看mysql的官方手册

http://dev.mysql.com/doc/refman/5.1/zh/stored-procedures.html#declare-handlers

中的创建存储过程章节里的下列内容,不能被忽视了:

?

下面是一个使用OUT参数的简单的存储程序的例子。例子为,在 程序被定义的时候,用mysql客户端delimiter命令来把语句定界符从 ;变为//。这就允许用在 程序体中的;定界符被传递到服务器而不是被mysql自己来解释。

?

mysql> delimiter //

?

mysql> CREATE PROCEDURE simpleproc (OUT param1 INT)

? ? -> BEGIN

? ? -> ? SELECT COUNT(*) INTO param1 FROM t;

? ? -> END

? ? -> //

Query OK, 0 rows affected (0.00 sec)

?

mysql> delimiter ;

?

mysql> CALL simpleproc(@a);

Query OK, 0 rows affected (0.00 sec)

?

mysql> SELECT @a;

+------+

| @a ? |

+------+

| 3 ? ?|

+------+

1 row in set (0.00 sec)

当使用delimiter命令时,你应该避免使用反斜杠(‘\’)字符,因为那是MySQL的 转义字符。

?

下列是一个例子,一个采用参数的函数使用一个SQL函数执行一个操作,并返回结果:

?

mysql> delimiter //

?

mysql> CREATE FUNCTION hello (s CHAR(20)) RETURNS CHAR(50)

? ? -> RETURN CONCAT('Hello, ',s,'!');

? ? -> //

Query OK, 0 rows affected (0.00 sec)

?

mysql> delimiter ;

?

mysql> SELECT hello('world');

+----------------+

| hello('world') |

+----------------+

| Hello, world! ?|

+----------------+

1 row in set (0.00 sec)

如果在存储函数中的RETURN语句返回一个类型不同于在函数的RETURNS子句中指定类型的值,返回值被强制为恰当的类型。比如,如果一个函数返回一个ENUM或SET值,但是RETURN语句返回一个整数,对于SET成员集的相应的ENUM成员,从函数返回的值是字符串。

?

?

还有后面的内容也说明了这个问题

?

20.2.7. BEGIN ... END复合语句

[begin_label:] BEGIN

? ? [statement_list]

END [end_label]

存储子程序可以使用BEGIN ... END复合语句来包含多个语句。statement_list 代表一个或多个语句的列表。statement_list之内每个语句都必须用分号(;)来结尾。

?

复合语句可以被标记。除非begin_label存在,否则end_label不能被给出,并且如果二者都存在,他们必须是同样的。

?

请注意,可选的[NOT] ATOMIC子句现在还不被支持。这意味着在指令块的开始没有交互的存储点被设置,并且在上下文中用到的BEGIN子句对当前交互动作没有影响。

?

使用多重语句需要客户端能发送包含语句定界符;的查询字符串。这个符号在命令行客户端被用delimiter命令来处理。改变查询结尾定界符;(比如改变为//)使得; 可被用在子程序体中。

?

?

总结起来就是因为存储过程里包含很多含缺省界定符号“;”的语句,如果不重新定义界定符的话,就只能以“;”为界定符一句一句的发给Mysql服务端解析,那么存储过程的第一句话肯定就语法错误了:

CREATE PROCEDURE p8()?

BEGIN?

DECLARE a INT;

?

然后后面的

DECLARE b INT;

也会报错,因为手册中规定DECLARE必须出现在BEGIN ?和 ?EDN之间,且在其它所有语句之前。这个单独出现的DECLARE b INT;就会报语法错误了。

?

现在明白了吧。。。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

mysql导入存储过程报错_mysql导入存储过程时declare报错的有关问题解决相关推荐

  1. mysql命令导入存储过程报错_mysql导入存储过程时declare报错的有关问题解决

    在导入存储过程时经常遇见下列DECLARE报错的问题: ? Error Code : 1064 You have an error in your SQL syntax; check the manu ...

  2. mysql用declare会报错_mysql导入存储过程时declare报错的问题解决

    在导入存储过程时经常遇见下列DECLARE报错的问题: Error Code : 1064 You have an error in your SQL syntax; check the manual ...

  3. mysql建立存储过程报错_MySQL创建存储过程(CREATE PROCEDURE)

    MySQL 存储过程是一些 SQL 语句的集合,比如有时候我们可能需要一大串的 SQL 语句,或者说在编写 SQL 语句的过程中需要设置一些变量的值,这个时候我们就完全有必要编写一个存储过程. 编写存 ...

  4. mysql导入数据报错_MySQL导入数据库时报错,MySQL server has go away

    MySQL server has gone away意思就是数据库挂了这个是因为导入数据导致mysql挂了,那么碰到数据库导入数据挂了要如何处理,下面来看看处理办法. 用mysqldump命令导出My ...

  5. mysql sql文件太大_MySQL导入的sql脚本文件过大解决方案

    运维同事近日给到我这边一个mysql的备份脚本文件,大小超过2.4G. 于是直接通过Navicat客户端导入脚本,但是报错:MySQL server has gone away. 于是想通过截取文件, ...

  6. mysql修改路径报错_mysql修改数据存储路径报错处理

    Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' 解决?: >>> vim ...

  7. mysql 存储过程改用户_Mysql修改存储过程相关权限问题

    在使用mysql数据库经常都会遇到这么一个问题,其它用户定义的存储过程,现在使用另一个用户却无法修改或者删除等:正常情况下存储过程的定义者对它有修改.删除的权限:但是其它的用户就要相于的授权,不然无法 ...

  8. mysql的存储过程与事务_mysql的存储过程与事务入门

    存储过程是: 通过一系列的SQL语句, 根据传入的参数(也可以没有), 通过简单的调用, 完成比单个SQL语句更复杂的功能, 存储在数据库服务器端,只需要编译过一次之后再次使用都不需要再进行编译.主要 ...

  9. mysql数据存储过程详解_mysql数据存储过程参数实例详解

    MySQL 存储过程参数有三种类型:in.out.inout.它们各有什么作用和特点呢? 一.MySQL 存储过程参数(in) MySQL 存储过程 "in" 参数:跟 C 语言的 ...

  10. mysql 存储过程 生成数据_mysql使用存储过程,批量生成测试数据

    1.存储过程代码 delimiter $$ DROP PROCEDURE IF EXISTS create_service_data$$ create procedure create_service ...

最新文章

  1. 分布式主键解决方案----Twitter 雪花算法的原理(Java 版)
  2. 简述Zookeeper作注册中心
  3. ACM ICPC 2011-2012 Northeastern European Regional Contest(NEERC)A ASCII Area
  4. boost::type_erasure::binding_of相关的测试程序
  5. xshell 6 连接debian系统拒绝了密码_原来连接Linux,还有这个方法
  6. Ubuntu 20.04 安装CUDA11.1 和cudnn 8.0.5
  7. 25% 的开发者认为 Rust 是最佳替代,最新 Go 开发者调查报告出炉
  8. 基于 Groovy 的自动化构建工具 Gradle 入门(转)
  9. 音乐播放器 EasyMusic (一)
  10. 图片简单上色,花开花落云卷云舒。
  11. maya绝招(1-20)
  12. Python输出emoji表情包
  13. DDG-1000下水
  14. 视频剪辑-OpenShot
  15. php读书笔记,读书笔记:《Modern PHP》
  16. 【Pandas入门教程】如何读取和写入表格数据
  17. Kibana 快速入门教程
  18. Linux下禁用root远程登录并且新建一个用户赋予root权限
  19. 腾讯云接口调用签名鉴权
  20. WebService CFX 实现

热门文章

  1. 网页加载速度优化方案
  2. selenium常用的API
  3. 获取代理电脑的https证书方法
  4. 【mac】配置本地数据库
  5. [BZOJ 3531][Sdoi2014]旅行(树链剖分+线段树)
  6. JS中showModalDialog (模态窗口)详细使用
  7. fio性能测试工具新添图形前端gfio
  8. 网络安全工程考试大纲
  9. 【转】兄弟俩玩的2000亿美元的公司,盖茨与鲍尔默:微软双雄上演终极接力
  10. linux下单网卡设双置IP