网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

perconaMYSQL5.7.135.7.14MYSQLDUMP导入报错delimiter(修改MYSQLDUMP代码)

percona 5.7.13 5.7.14 MySQLDUMP备份完成后不能呢导回去,
文件一大了非常麻烦,最近遇到这样的问题。
[root@testmy client]#  /mysqldata/mysql3308/bin/mysql -uroot -pEnter 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 -pEnter 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 -pEnter password: 
[root@testmy client]# 


不会报错了。


网页标题:perconaMYSQL5.7.135.7.14MYSQLDUMP导入报错delimiter(修改MYSQLDUMP代码)
文章URL:http://bjjierui.cn/article/gcggji.html

其他资讯