zoukankan      html  css  js  c++  java
  • JAVA实现MySQL数据库备份及恢复

    前注:

      代码基本来源网络,这里作为分享。

    描述:

      最近客户提出了一个需求,就是需要在网页端实现数据库的备份和恢复,由于工作经验尚浅,我第一时间拒绝了,但后来在网络上查找资料,发现很容易就能实现。算是一次打脸的经历,这里记录一下。

    代码:

    其实核心代码只有一句:Runtime.getRuntime().exec("************执行命令************");

    另外,MySQL版本不同似乎执行命令也会有所差异。例如,同事使用MySQL3.7版本进行备份时,导出执行exec()后,备份文件无内容。

    package com.xxx.core.db;
    
    import java.io.*;
    
    /**
     * @Auther: ErDong
     * @Date: 2019/10/28 0028 08:50
     * @Description:
     */
    public class MySQLDatabaseBackup {
    
        /**
         * Java代码实现MySQL数据库导出
         *
         * @author ErDong
         * @param hostIP MySQL数据库所在服务器地址IP
         * @param userName 进入数据库所需要的用户名
         * @param password 进入数据库所需要的密码
         * @param savePath 数据库导出文件保存路径
         * @param fileName 数据库导出文件文件名
         * @param databaseName 要导出的数据库名
         * @return 返回true表示导出成功,否则返回false。
         */
        public static boolean exportDatabase(String hostIP, String userName, String password, String savePath, String fileName, String databaseName) throws InterruptedException {
            File saveFile = new File(savePath);
            if (!saveFile.exists()) {// 如果目录不存在
                saveFile.mkdirs();// 创建文件夹
            }
            if(!savePath.endsWith(File.separator)){
                savePath = savePath + File.separator;
            }
    
            PrintWriter printWriter = null;
            BufferedReader bufferedReader = null;
            try {
                printWriter = new PrintWriter(new OutputStreamWriter(new FileOutputStream(savePath + fileName), "utf8"));
                Process process = Runtime.getRuntime().exec(" mysqldump -h" + hostIP + " -u" + userName + " -p" + password + " --set-charset=UTF8 " + databaseName);
                InputStreamReader inputStreamReader = new InputStreamReader(process.getInputStream(), "utf8");
                bufferedReader = new BufferedReader(inputStreamReader);
                String line;
                while((line = bufferedReader.readLine())!= null){
                    printWriter.println(line);
                }
                printWriter.flush();
                if(process.waitFor() == 0){//0 表示线程正常终止。
                    return true;
                }
            }catch (IOException e) {
                e.printStackTrace();
            } finally {
                try {
                    if (bufferedReader != null) {
                        bufferedReader.close();
                    }
                    if (printWriter != null) {
                        printWriter.close();
                    }
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
            return false;
        }
    
        /**
         * 导入Mysql数据库
         * @param hostIP 数据库地址
         * @param hostPort 端口
         * @param userName 用户名
         * @param password 密码
         * @param importFilePath 数据库文件路径
         * @param sqlFileName 要导入的文件名
         * @param databaseName 要导入的数据库名
         * @return
         * @throws InterruptedException
         */
        public static boolean importDatabase(String hostIP, String hostPort, String userName, String password, String importFilePath, String sqlFileName, String databaseName) {
            File imporFile = new File(importFilePath);
            if (!imporFile.exists()) {
                imporFile.mkdirs();
            }
            if (!importFilePath.endsWith(File.separator)) {
                importFilePath = importFilePath + File.separator;
            }
            try {
                // 创建数据库:mysqladmin -h 192.168.1.40 -u root -proot create icqr
                String createDB = "mysqladmin -h " + hostIP + " -u " + userName + " -p" + password + " create " + databaseName;
                Runtime.getRuntime().exec(createDB);
                // 写入数据:mysql -h127.0.0.1 -uroot -P3306 -p test<D:ackupDatabase
                Process process = Runtime.getRuntime().exec("cmd /C" + "mysql -h" + hostIP+" -P" + hostPort + " -u" + userName + " -p" + password + " " + databaseName + "<" + importFilePath+sqlFileName);
                if (process.waitFor() == 0) {
                    return true;
                }
            } catch (IOException e) {
                e.printStackTrace();
            } catch (InterruptedException e){
                e.printStackTrace();
            }
            return false;
        }
    
        public static void main(String[] args){
            Boolean result = true;
    //        result = importDatabase("127.0.0.1", "3306", "root", "password", "D:\backupDatabase", "2014-10-14.sql", "databaseName");
            try {
                result = exportDatabase("127.0.0.1", "root", "password", "D:\backupDatabase\"," backup.sql", "databaseName");
            } catch (Exception e) {
                e.printStackTrace();
            }
            if(result) {
                System.out.println("数据库备份成功");
            } else {
                System.out.println("数据库备份失败!!!");
            }
        }
    }

     

     

      此

     

      处

     

      留

     

      白

     

  • 相关阅读:
    jQuery插件开发入门
    [转]JS学习总结-技巧、方法、细节
    JS无法获取display为none的隐藏元素的宽度和高度的解决方案
    vuejs2.0运用原生js实现简单的拖拽元素功能
    HTML5效果:Canvas 实现圆形进度条并显示数字百分比
    git常用命令总结以及用github来展示你的前端页面
    jQuery 对AMD的支持(Require.js中如何使用jQuery)
    vue+springboot上传和下载附件功能
    springboot+vue实现文件上传
    Spring boot+Vue全栈开发---Spring Boot文件上传
  • 原文地址:https://www.cnblogs.com/xfc-exclave/p/11842413.html
Copyright © 2011-2022 走看看