percona MYSQL 5.7.13 5.7.14 MYSQLDUMP 匯入報錯delimiter (修改MYSQLDUMP程式碼)
percona 5.7.13 5.7.14 MYSQLDUMP備份完成後不能呢導回去,
檔案一大了非常麻煩,最近遇到這樣的問題。
[root@testmy client]# /mysqldata/mysql3308/bin/mysql -uroot -p<log.sql
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<log.log
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<log.log
Enter password:
[root@testmy client]#
不會報錯了。
</log.log
</log.log
</log.sql
檔案一大了非常麻煩,最近遇到這樣的問題。
[root@testmy client]# /mysqldata/mysql3308/bin/mysql -uroot -p<log.sql
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<log.log
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<log.log
Enter password:
[root@testmy client]#
不會報錯了。
</log.log
</log.sql
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7728585/viewspace-2125602/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- mysqldump匯入匯出mysql資料庫MySql資料庫
- mysql5.6 mysqldump備份報錯MySql
- mysqldump匯出報錯"mysqldump: Error 2013 ... during query when dumping tableMySqlError
- mysql 匯入 mysqldump 備份得資料保 gone away錯誤MySqlGo
- mysqldump匯入匯出表資料MySql
- Navicat、into outfile、mysql命令、mysqldump、mysqlpump、mydumper匯出匯入資料MySql
- MySQL mysqldump資料匯出詳解MySql
- MySQL mysqldump命令MySql
- Mysqldump匯出亂碼問題排查MySql
- mysqldump匯出資料MySql
- 【MySql】mysqldump 的用法MySql
- MySQL修改字符集(mysqldump轉換全庫)MySql
- mysqldump壓縮備份匯出匯入(含定期備份shell指令碼)MySql指令碼
- event中有多餘的分號引起mysqldump備份匯入時報錯MySql
- 【Mysql】mysqldump 匯出各種場景的應用MySql
- mysqldump匯出匯入所有庫、某些庫、某些表的例子MySql
- mysqldump錯誤處理MySql
- MySQL入門學習之——實戰mysqldumpMySql
- MYSQL-mysqldump學習MySql
- mysqldump匯入儲存過程和其註釋MySql儲存過程
- mysqldump只匯入資料或只導結構MySql
- Mysql匯出表結構及表資料 mysqldump用法MySql
- mysqldumpMySql
- MySQL:MTS和mysqldump死鎖MySql
- mysql 邏輯備份 (mysqldump)MySql
- Mysqldump 匯出表結構異常MySql
- mysqldump 備份指令碼MySql指令碼
- mysqldump備份指令碼MySql指令碼
- MySQL 5.5 Slave節點備份指令碼(mysqldump)MySql指令碼
- mysqldump來備份MYSQL資料庫(指令碼)MySql資料庫指令碼
- 【mysqldump】mysqldump及備份恢復示例MySql
- mysql 大表mysqldump遷移方案MySql
- MySQL 5.5 mysqldump備份說明MySql
- Mysql不鎖表進行MysqldumpMySql
- MySQL的mysqldump工具的基本用法MySql
- mysql 備份資料庫 mysqldumpMySql資料庫
- mysql資料庫遷移 mysqldumpMySql資料庫
- mysqldump流程MySql