使用mysqldump 对数据库进行备份的乱码问题
2013-06-27 22:56
405 查看
最近在做项目的工程中,由于系统中需要提供数据库备份的功能,经过网上一番搜索,觉得采用简单的mysqldump
(1)java代码
String backupSQL = "cmd /c mysqldump -urootdd --extended-insert=false -hlocalhost fts> "
+ DB_BACKUPFILE_PATH + " ";
Runtime runtime = Runtime.getRuntime();
System.out.println(runtime.exec(backupSQL));
通过执行上面的代码段的出来的文件中,中文部分都已乱码出现,起初怀疑是数据库的编码有关,于是通过以下方式来查询数据库的编码
(2) >show variables like 'character%';
经过以上步骤可以确定数据库的编码是没有问题的,经过再次网上搜索 得到如下结论
"如果MySQL服务器上的字符集是 latin1 或者其他的的,mysqldump 出来的中文都是乱码!一个简单的办法是加上默认字符集选项,如:
mysqldump [-h 127.0.0.1 -P 3307 ] -u username --default-character-set=gbk -p databasename > dumpfile.txt,
--default-character-set 知道数据内容是中文时可以指定为 gbk,这样即使数据库本身设置字符集为 latin1 出来的文件中文也能正常!", 最后将代码改成如下形式
(3)最终java 代码
String backupSQL = "cmd /c mysqldump -urootdd --default-character-set=gbk --opt --extended-insert=false -hlocalhost fts> "
+ DB_BACKUPFILE_PATH + " ";
Runtime runtime = Runtime.getRuntime();
System.out.println(runtime.exec(backupSQL));
经过以上修改,终于搞定,导出的文件中的中文时正常显示的
(1)java代码
String backupSQL = "cmd /c mysqldump -urootdd --extended-insert=false -hlocalhost fts> "
+ DB_BACKUPFILE_PATH + " ";
Runtime runtime = Runtime.getRuntime();
System.out.println(runtime.exec(backupSQL));
通过执行上面的代码段的出来的文件中,中文部分都已乱码出现,起初怀疑是数据库的编码有关,于是通过以下方式来查询数据库的编码
(2) >show variables like 'character%';
经过以上步骤可以确定数据库的编码是没有问题的,经过再次网上搜索 得到如下结论
"如果MySQL服务器上的字符集是 latin1 或者其他的的,mysqldump 出来的中文都是乱码!一个简单的办法是加上默认字符集选项,如:
mysqldump [-h 127.0.0.1 -P 3307 ] -u username --default-character-set=gbk -p databasename > dumpfile.txt,
--default-character-set 知道数据内容是中文时可以指定为 gbk,这样即使数据库本身设置字符集为 latin1 出来的文件中文也能正常!", 最后将代码改成如下形式
(3)最终java 代码
String backupSQL = "cmd /c mysqldump -urootdd --default-character-set=gbk --opt --extended-insert=false -hlocalhost fts> "
+ DB_BACKUPFILE_PATH + " ";
Runtime runtime = Runtime.getRuntime();
System.out.println(runtime.exec(backupSQL));
经过以上修改,终于搞定,导出的文件中的中文时正常显示的
相关文章推荐
- 使用mysqldump 对数据库进行备份的乱码问题
- 解决使用cmd或powershell进行数据库(MySQL,SQLite3...)查询时中文乱码的问题
- 使用mysqldump、into outfile和load data进行数据库导入导出备份
- 使用mysql自带工具mysqldump进行全库备份以及source命令恢复数据库
- 使用hibernate框架对mysql进行操作时数据库乱码问题
- 使用mysqldump、into outfile和load data进行数据库导入导出备份
- 使用MYSQL数据库备份指令MYSQLDUMP备份bugzilla数据库
- SQL:使用备份向导、SQL命令、导出数据三种方式对已建立的数据库进行备份
- Linux 下mysqldump备份的数据使用vim打开乱码
- MySQL中使用mysqldump命令进行备份与恢复
- 使用 mysqldump, lvm snapshot 和 Xtrabackup 对mysql 进行备份
- 使用DBUnit进行数据库备份与恢复
- 使用ObjectOutputStream进行socket通信的时候出现固定读到四个字节乱码的问题
- 使用mysqldump工具进行mysql备份
- 使用linux客户端执行shell脚本创建数据库初始化数据库中文乱码问题
- PHP使用PDO操作数据库的乱码问题解决方法
- 使用Percona Xtrabackup对数据库进行部分备份
- 第二步 使用mysqldump 和 crontab定时任务定时备份数据库
- 使用mysqldump 和cron 每天定时备份数据库
- MySQL利用mysqldump进行数据库备份及还原