zoukankan      html  css  js  c++  java
  • 使用mysqldump 对数据库进行备份的乱码问题

    最近在做项目的工程中,由于系统中需要提供数据库备份的功能,经过网上一番搜索,觉得采用简单的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));


    经过以上修改,终于搞定,导出的文件中的中文时正常显示的

  • 相关阅读:
    出错处理函数abort、exit、atexit、strerror. . .
    linux查询系统信息命令
    [转载]比google和百度强十倍的搜索类网站
    陶  朱  商  经
    ip的划分,超详细.【网管常识】
    linux的hostname修改详解
    勤于寻找谈话资料
    Windows常用命令集
    C语言中printf格式
    How to disable SELinux
  • 原文地址:https://www.cnblogs.com/jiangu66/p/3161557.html
Copyright © 2011-2022 走看看