mysql5.7 delimiter_percona MYSQL 5.7.13 5.7.14 MYSQLDUMP 导入报错delimiter (修改MYSQLDUMP代码)...

percona MYSQL 5.7.13 5.7.14 MYSQLDUMP 导入报错delimiter (修改MYSQLDUMP代码)

重庆八怪

2016-09-26 15:12:22

浏览1094

percona 5.7.13 5.7.14 MYSQLDUMP备份完成后不能呢导回去,

文件一大了非常麻烦,最近遇到这样的问题。

[root@testmy client]#  /mysqldata/mysql3308/bin/mysql -uroot -p

Enter password:

ERROR at line 63: DELIMITER must be followed by a 'delimiter' character or string

ERROR 1064 (42000) at line 64: 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 4

其实这里就是DELIMITER 后面的;;解析了,只要把;;转变为$$ 就好了.

[root@testmy client]# sed -i "s/;;/$$/g" log.sql

[root@testmy client]#  /mysqldata/mysql3308/bin/mysql -uroot -p

Enter password:

[root@testmy client]#

当然我这里是测试库,如果真的是线上库量非常大作sed谈何容易。所以决定从mysqldump下手改一下标识即可。

下面是修改部分,因为MYSQLDUMP是独立的工具,这些函数全是static函数,可以放心修改,如果是外部函数真

还不敢改,修改源码的client/mysqldump.c 如下部分修改了:

static uint dump_events_for_db(char *db)

2547            fprintf(sql_file,

2548            "DELIMITER ;;\n"

2549            "%s ;;\n"

2550            "DELIMITER ;\n",

修改为

static uint dump_events_for_db(char *db)

2547            fprintf(sql_file,

2548            "DELIMITER $$\n"

2549            "%s $$\n"

2550            "DELIMITER ;\n",

static void dump_trigger_old(FILE *sql_file, MYSQL_RES *show_triggers_rs,

MYSQL_ROW *show_trigger_row,

const char *table_name)

3247        fprintf(sql_file,

3248          "DELIMITER ;;\n"

3249          "/*!50003 SET SESSION SQL_MODE=\"%s\" */;;\n"

3250          "/*!50003 CREATE */ ",

3251          (*show_trigger_row)[6]);

修改为:

3247        fprintf(sql_file,

3248          "DELIMITER $$\n"

3249          "/*!50003 SET SESSION SQL_MODE=\"%s\" */$\n"

3250          "/*!50003 CREATE */ ",

3251          (*show_trigger_row)[6]);

static int dump_trigger(FILE *sql_file, MYSQL_RES *show_create_trigger_rs,

const char *db_name,

const char *db_cl_name)

3334            fprintf(sql_file,

3335            "DELIMITER ;;\n"

3336            "/*!50003 %s */;;\n"

3337            "DELIMITER ;\n",

3338            (const char *) (query_str != NULL ? query_str : row[2]));

修改为:

3334            fprintf(sql_file,

3335            "DELIMITER $$\n"

3336            "/*!50003 %s */$$\n"

3337            "DELIMITER ;\n",

3338            (const char *) (query_str != NULL ? query_str : row[2]));

最后需要重新cmake一下make编译一下不需要make install 把mysqldump 拷贝到相应的目录即可

修改后

[root@testmy client]# more log.log |grep '$$'

DELIMITER $$

end */$$

DELIMITER $$

end $$

[root@testmy client]#  /mysqldata/mysql3308/bin/mysql -uroot -p

Enter password:

[root@testmy client]#

不会报错了。

本文首发在云栖社区,遵循云栖社区版权声明:本文内容由互联网用户自发贡献,版权归用户作者所有,云栖社区不为本文内容承担相关法律责任。云栖社区已在2020年6月升级到阿里云开发者社区。如果您发现有涉嫌抄袭的内容,请填写侵权投诉表单进行举报,一经查实,阿里云开发者社区将协助删除涉嫌侵权内容。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值