2018年6月29日14:00:48

阅读数:1534

  今天整了整整一整天,终于使用Java在线备份和还原MySQL数据库了,哎,备份倒是很快,就是在还原的时候遇到了一个问题,也不报错,结果将sql语句放到cmd中一运行才知道是编码的问题,下面代码。

首先将将Mysql的环境变量配上:你的mysql安装目录\bin;,放到系统变量中path变量中,最好是开始Mysql的远程连接的功能,将mysql数据库中的user表中的你连接mysql的用户的host字段设置为%号。

  1.  
    package com.hancai.base.admin.action;
  2.  
     
  3.  
    import java.io.BufferedReader;
  4.  
    import java.io.File;
  5.  
    import java.io.FileInputStream;
  6.  
    import java.io.FileOutputStream;
  7.  
    import java.io.IOException;
  8.  
    import java.io.InputStream;
  9.  
    import java.io.InputStreamReader;
  10.  
    import java.io.OutputStream;
  11.  
    import java.io.OutputStreamWriter;
  12.  
     
  13.  
     
  14.  
     
  15.  
    public class Test {
  16.  
    public static void main(String[] args) throws IOException{
  17.  
    backup("d:\\d.sql");
  18.  
    recover("d:\\d.sql");
  19.  
    }
  20.  
    public static void backup(String path) throws IOException{
  21.  
    Runtime runtime = Runtime.getRuntime();
  22.  
    //-u后面是用户名,-p是密码-p后面最好不要有空格,-family是数据库的名字
  23.  
    Process process = runtime.exec("mysqldump -u root -p123456 family");
  24.  
    InputStream inputStream = process.getInputStream();//得到输入流,写成.sql文件
  25.  
    InputStreamReader reader = new InputStreamReader(inputStream);
  26.  
    BufferedReader br = new BufferedReader(reader);
  27.  
    String s = null;
  28.  
    StringBuffer sb = new StringBuffer();
  29.  
    while((s = br.readLine()) != null){
  30.  
    sb.append(s+"\r\n");
  31.  
    }
  32.  
    s = sb.toString();
  33.  
    System.out.println(s);
  34.  
    File file = new File(path);
  35.  
    file.getParentFile().mkdirs();
  36.  
    FileOutputStream fileOutputStream = new FileOutputStream(file);
  37.  
    fileOutputStream.write(s.getBytes());
  38.  
    fileOutputStream.close();
  39.  
    br.close();
  40.  
    reader.close();
  41.  
    inputStream.close();
  42.  
    }
  43.  
    public static void recover(String path) throws IOException{
  44.  
    Runtime runtime = Runtime.getRuntime();
  45.  
    //-u后面是用户名,-p是密码-p后面最好不要有空格,-family是数据库的名字,--default-character-set=utf8,这句话一定的加
  46.  
    //我就是因为这句话没加导致程序运行成功,但是数据库里面的内容还是以前的内容,最好写上完成的sql放到cmd中一运行才知道报错了
  47.  
    //错误信息:
  48.  
    //mysql: Character set 'utf-8' is not a compiled character set and is not specified in the '
  49.  
    //C:\Program Files\MySQL\MySQL Server 5.5\share\charsets\Index.xml' file ERROR 2019 (HY000): Can't
  50.  
    // initialize character set utf-8 (path: C:\Program Files\MySQL\MySQL Server 5.5\share\charsets\),
  51.  
    //又是讨人厌的编码问题,在恢复的时候设置一下默认的编码就可以了。
  52.  
    Process process = runtime.exec("mysql -u root -p123456 --default-character-set=utf8 family");
  53.  
    OutputStream outputStream = process.getOutputStream();
  54.  
    BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(path)));
  55.  
    String str = null;
  56.  
    StringBuffer sb = new StringBuffer();
  57.  
    while((str = br.readLine()) != null){
  58.  
    sb.append(str+"\r\n");
  59.  
    }
  60.  
    str = sb.toString();
  61.  
    System.out.println(str);
  62.  
    OutputStreamWriter writer = new OutputStreamWriter(outputStream,"utf-8");
  63.  
    writer.write(str);
  64.  
    writer.flush();
  65.  
    outputStream.close();
  66.  
    br.close();
  67.  
    writer.close();
  68.  
    }
  69.  
    }

下载地址:Java在线备份和还原MySQL数据库

转载请注明出处,谢谢!

Java在线备份和还原MySQL数据库。的更多相关文章

  1. 快速备份和还原 MySQL 数据库的另一种方法

    一直使用 SQL Server 作为公司产品的数据库来存储系统数据,所以备份还原一直都不是问题,因为 SQL Server 的备份还原非常迅速和易用.但今年公司改变策略,使用起 MySQL 数据库作为 ...

  2. 备份与还原mysql 数据库的常用命令。

    一.备份数据: Mysqldump常用命令: mysqldump -u用户名 -p密码 --databases 数据库1 数据库2 > xxx.sql 常见选项: -u: 用户名 -p: 密码 ...

  3. Navicat备份、还原mysql数据库

    注:本文为原创,转载请附带链接:https://www.cnblogs.com/stm32stm32

  4. 备份还原mysql数据库

    Windows下cmd命令行中备份还原mysql数据库 先cmd 上cd  到mysql的安装bin目录下,然后再运行下面的命令. 例如:cd C:\Program Files\MySQL\MySQL ...

  5. C#备份还原MySql数据库

    原文:C#备份还原MySql数据库 项目结束,粘点代码出来让Google或Baidu一下,原因是现在还搜不到这么现成的 调用MySql的工具mysqldump来实现. 类Cmd来实现调用cmd命令, ...

  6. 使用数据泵expdp、impdp备份和还原oracle数据库

    前面我已经整理过EXP 和 IMP备份和还原Oracle数据库的方法 今天我们只讲使用数据泵 expdp 和impdp的方法,有的同学会问他们有什么差别呢? EXP和IMP是客户端工具程序,它们既可以 ...

  7. java中用activiti插件连接mysql数据库,自动建表过程中,在配置mysql架包路径“org.activiti.engine.ActivitiException: couldn't check if tables “

    java中用activiti插件连接mysql数据库,出现错误: org.activiti.engine.ActivitiException: couldn't check if tables are ...

  8. xtrabackup备份还原MySQL数据库

    mysqldump 备份鉴于其自身的某些特性(锁表,本质上备份出来insert脚本或者文本,不支持差异备份),不太适合对实时性要求比较高的情况Xtrabackup可以解决mysqldump存在的上述的 ...

  9. PHP 备份还原 MySql 数据库

    原生 PHP 备份还原 MySql 数据库 支持 MySql,PDO 两种方式备份还原 php5.5 以上的版本建议开启pdo扩展,使用 pdo 备份还原数据 备份文件夹 db_backup.impo ...

随机推荐

  1. Django学习手册 - 创建Django工程项目以及APP

    前置步骤: 下载python,django 并且安装好 python 解释器以及django模块. 整体步骤阐述: 创建django工程项目 步骤一:进入安装的python目录 步骤二:输入创建工程的 ...

  2. P4001 [ICPC-Beijing 2006]狼抓兔子

    题目地址:P4001 [ICPC-Beijing 2006]狼抓兔子 平面图 边与边只在顶点相交的图. 对偶图 对于一个平面图,都有其对应的对偶图. 平面图被划分出的每一个区域当作对偶图的一个点: 平 ...

  3. dubbo源码分析4——SPI机制_ExtensionFactory类的作用

    ExtensionFactory的源码: @SPI public interface ExtensionFactory { /** * Get extension. * * @param type o ...

  4. redis启动异常

    在官网上下载redis包,解压后启动. 启动redis报下面的错误! *** FATAL CONFIG FILE ERROR *** Reading the configuration file, a ...

  5. 修改Linux主机名与IP之间的映射关系

    linux主机版本: Distributor ID: UbuntuDescription: Ubuntu 14.10Release: 14.10 一.修改linux主机名 1.使用hostname命令 ...

  6. 题解-PKUWC2018 Minimax

    Problem loj2537 Solution pkuwc2018最水的一题,要死要活调了一个多小时(1h59min) 我写这题不是因为它有多好,而是为了保持pkuwc2018的队形,与这题类似的有 ...

  7. apache做反向代理服务器

    apache代理分为正向代理和反向代理: 1 正向代理: 客户端无法直接访问外部的web,需要在客户端所在的网络内架设一台代理服务器,客户端通过代理服务器访问外部的web(需要在客户端的浏览器中设置代 ...

  8. Spring Boot (一): Spring Boot starter自定义

    前些日子在公司接触了spring boot和spring cloud,有感于其大大简化了spring的配置过程,十分方便使用者快速构建项目,而且拥有丰富的starter供开发者使用.但是由于其自动化配 ...

  9. C#遍历指定文件夹中的所有文件(转)

    C#遍历指定文件夹中的所有文件 DirectoryInfo TheFolder=new DirectoryInfo(folderFullName);//遍历文件夹foreach(DirectoryIn ...

  10. JdbcUtil

    package com.todaytech.pwp.core.exception; public class BizException extends RuntimeException { publi ...