mysql命令导入存储过程报错_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;就会报语法错误了。
?
现在明白了吧。。。
mysql命令导入存储过程报错_mysql导入存储过程时declare报错的有关问题解决相关推荐
- mysql用declare会报错_mysql导入存储过程时declare报错的问题解决
在导入存储过程时经常遇见下列DECLARE报错的问题: Error Code : 1064 You have an error in your SQL syntax; check the manual ...
- mysql 中函数如何转存_mysql 导入导出数据库以及函数、存储过程 【转】
MySQL常用导出数据命令: 1.mysql导出整个数据库 mysqldump -hhostname -uusername -ppassword databasename > backupfil ...
- mysql命令导出表结构文件夹_mysql,命令导入\导出表结构或数据
1.导出整个数据库 mysqldump -u用户名 -p密码 数据库名 > 导出的文件名 C:\Users\jack> mysqldump -uroot -pmysql db1 > ...
- mysql建立存储过程报错_MySQL创建存储过程(CREATE PROCEDURE)
MySQL 存储过程是一些 SQL 语句的集合,比如有时候我们可能需要一大串的 SQL 语句,或者说在编写 SQL 语句的过程中需要设置一些变量的值,这个时候我们就完全有必要编写一个存储过程. 编写存 ...
- mysql修改路径报错_mysql修改数据存储路径报错处理
Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' 解决?: >>> vim ...
- mysql load报错_mysql:执行LOAD DATA LOCAL 报错
mysql:执行LOAD DATA LOCAL 报错. 我使用navicat for mysql 连接 mysql服务器执行local 可以正常执行 . show VARIABLES like '% ...
- Mysql命令行下实现数据的导入
昨天有个哥们博客搬家,数据库死活搞不上去,用mysql-front连上去也不行. 就向我求助了,我就帮他搞,一会就搞定.现在我就把我的数据导入过程给大家分享下. 本来我机器上装了mysql,所以我就直 ...
- mysql命令行批量添加数据_mysql命令行批量插入100条数据命令
先介绍一个关键字的使用: delimiter 定好结束符为"$$",(定义的时候需要加上一个空格) 然后最后又定义为";", MYSQL的默认结束符为" ...
- mysql的存储过程与事务_mysql的存储过程与事务入门
存储过程是: 通过一系列的SQL语句, 根据传入的参数(也可以没有), 通过简单的调用, 完成比单个SQL语句更复杂的功能, 存储在数据库服务器端,只需要编译过一次之后再次使用都不需要再进行编译.主要 ...
最新文章
- Attribute在.net编程中的应用
- 2019中国人工智能年度评选启幕,3大奖项,锁定AI Top玩家
- 文巾解题 11. 盛最多水的容器
- 在java中使用关键字导入包_java中import关键字的使用方法
- .net core DI 注册 Lazy 类型
- 开始把其他的博客搬家到这里了
- 数据分析案例:亚洲国家人口数据计算
- 制作Oracle dockerfile镜像
- java连接远程带有密码的mongodb数据库
- Flutter视图基础简介--Widget、Element、RenderObject
- PHP读取表格都是精度,php 小数精度问题
- [BScroll warn]: Can not resolve the wrapper DOM. Vue better-scroll
- 直播内容抢先看|基于 AUTOSAR 技术的 SOA 软件平台实践
- windows查看自己安装的Mysql版本
- b站缓存的.blv和.m4s视频文件格式转换
- Learning-Based Approximation of Interconnect Delay and Slew in Signoff Timing Tools
- vue v-for遍历动态展示元素数量
- python图片截取斜四边形_opencv 截取任意四边形区域的图像
- 树莓派外接网卡实现监听wifi
- docker镜像迁移mysql启动报错_README.md
热门文章
- think in java i o_5.[Think in Java笔记]Java IO系统
- opa847方波放大电路_电子设计竞赛教程-信号发生电路
- Python函数16道入门练习题
- 13道Python数组练习题
- python基础教程:python中@的用法
- python3 ftp文件传输
- 【opencv4】opencv视频教程 C++(opencv教程)2、加载imread()(以灰度加载),修改,保存图像
- C语言编译链接生成可执行文件四大步骤:预处理(-E)->编译(-S)->汇编(-c) ->链接
- 【car】购买新能源电动汽车的几个注意事项
- Intel Realsense D435 多摄像头多线程目标识别架构