1 public ResultData backupDatabase(Integer type) {
2 // 构建备份sql的文件名
3 String sqlFileName = "test" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()) + ".sql";
4 PrintWriter printWriter = null;
5 BufferedReader bufferedReader = null;
6
7 try {
8 // 查询所需备份的表(备份的具体哪些表由数据库配置)
9 List<SwBackUpTable> backUpTableList = dataManagerDao.getBackupTables();
10 StringBuilder stringBuilder = new StringBuilder("");
11
12 // 所需备份的表的拼接字符串
13 for (SwBackUpTable swBackUpTable : backUpTableList) {
14 stringBuilder.append(" ").append(swBackUpTable.getTableName());
15 }
16 String backupTables = stringBuilder.toString();
17
18 // 构建备份sql文件路径
19 File savePath = new File(backupSqlPath);
20 if (!savePath.exists()) {
21 // 创建文件夹
22 savePath.mkdirs();
23 }
24 String sqlPath = backupSqlPath + "/" + sqlFileName;
25
26 //导出指定数据库指定表的结构和数据
27 String command = mysqlPath + backupTables;
28 System.out.println("mysql执行指令:" + command);
29 Process process = Runtime.getRuntime().exec(command);
30
31 printWriter = new PrintWriter(new OutputStreamWriter(new FileOutputStream(sqlPath), "utf8"));
32 InputStreamReader inputStreamReader = new InputStreamReader(process.getInputStream(), "utf8");
33 bufferedReader = new BufferedReader(inputStreamReader);
34
35 String line;
36 while ((line = bufferedReader.readLine()) != null) {
37 printWriter.println(line);
38 }
39 printWriter.flush();
40
41 //0 表示线程正常终止。
42 if (process.waitFor() == 0) {
43 System.out.println("备份数据成功");
44 }
45 System.out.println("数据备份路径==>" + sqlPath);
46
47 // 备份记录
48 BackUpRecords record = new SwBackUpRecords();
49 record.setName(sqlFileName);
50 record.setTables(backupTables);
51 record.setSource(type);
52 record.setPath(sqlPath);
53 record.setBackupTime(new Date());
54 dataManagerDao.insertRecords(record);
55
56 return ResultData.success("备份成功");
57 } catch (Exception e) {
58 e.printStackTrace();
59 return ResultData.success("备份失败");
60 } finally {
61 //关闭流
62 try {
63 if (bufferedReader != null) {
64 bufferedReader.close();
65 }
66 if (printWriter != null) {
67 printWriter.close();
68 }
69 } catch (IOException e) {
70 e.printStackTrace();
71 }
72 }
73 }

以上代码中,type字段为业务所需,无需关注.

  mysqlPath: /user/local/mysql/mysql-8.0/bin/mysqldump -uroot -proot Test

    Test为数据库名

  backupSqlPath:服务器存放备份sql的文件夹路径(如:/home/date/backupSql)

Java-Java调用mysqldump进行数据库备份的更多相关文章

  1. mysqldump 把数据库备份到异地的服务器

    原文:http://www.open-open.com/code/view/1420121471484 这个方法可以把通过mysqldump 把本地数据库备份到远端主机, 中间数据的传输通过 ssh ...

  2. JSP 实现 之 调用java方法实现MySQL数据库备份和恢复

    package cn.qm.db; import java.io.BufferedReader; import java.io.DataInputStream; import java.io.IOEx ...

  3. windows下Java调用mysql的客户端备份和恢复

    这种东西没啥好聊的,其实就是Java执行dos界面下的命令,不过有些要注意就是了,真实dos下面的命令和java调用的windows系统的接口其实还是有一点不同. /** * @param hostI ...

  4. java 实现mysql数据库备份

    package com.itenp.gen.action; import java.io.BufferedReader; import java.io.FileInputStream; import ...

  5. Java实现MySQL数据库备份(二)

    权声明:本文为博主原创文章,未经博主允许不得转载. 博客<Java实现MySQL数据库备份(一)>使用I/O流的方式实现了MySQL数据库的备份,这种方法比较繁杂,下面介绍另一种备份MyS ...

  6. Java实现MySQL数据库备份(一)

    下班了,利用闲暇时间总结一下如何使用Java语言实现MySQL数据库备份: import java.io.BufferedReader; import java.io.File; import jav ...

  7. Java实现mysql数据库备份

    Runtime是一个与JVM运行时环境有关的类,这个类是Singleton的. Runtime.getRuntime()可以取得当前JVM的运行时环境,这也是在Java中唯一一个得到运行时环境的方法. ...

  8. Java达到MySQL数据库备份(两)

    博客<Java实现MySQL数据库备份(一)>使用I/O流的方式实现了MySQL数据库的备份,这样的方法比較繁杂.以下介绍还有一种备份MySQL数据库的方法: import java.io ...

  9. Java实现Oracle数据库备份

    今天将很早就实现的一个Oracle数据库备份功能粘贴出来,这个功能是在大学做阶段设计时写的: import java.io.File; import java.io.IOException; /** ...

  10. jsp页面:js方法里嵌套java代码(是操作数据库的),如果这个js 方法没被调用,当jsp页面被解析的时候,不管这个js方法有没有被调用这段java代码都会被执行?

    jsp页面:js方法里嵌套java代码(是操作数据库的),如果这个js 方法没被调用,当jsp页面被解析的时候,不管这个js方法有没有被调用这段java代码都会被执行? 因为在解析时最新解析的就是JA ...

随机推荐

  1. 请求的URI过长:414 Request-URI Too Large

    问题:在项目中遇到使用get 请求,发现前端传递的参数超过nginx 服务器的限制.三种解决方法(任选一种): 1.在nginx配置文件里面把这两个缓存加大 文件位置:conf/nginx.conf ...

  2. Node.js学习笔记----day01

    认真学习,认真记录,每天都要有进步呀!!! 加油叭!!! 一.Node.js的简介 Node.js是什么 (1)Node.js不是一门语言 (2) Node.js也不是库,也不是框架 (3)Node. ...

  3. 0基础搭建基于OpenAI的ChatGPT钉钉聊天机器人

    前言:以下文章来源于我去年写的个人公众号.最近chatgpt又开始流行,顺便把原文内容发到博客园上遛一遛. 注意事项和指引: 注册openai账号,需要有梯子进行访问,最好是欧美国家的IP,亚洲国家容 ...

  4. 【学习日志】Cglib动态代理和JDK动态代理的对比

      Cglib JDK Proxy 实现方式 生成被代理类的子类 通过被代理类实现的接口+反射 速度 慢(曾经快于JDK Proxy,但JDK Proxy几次迭代后逐渐落后) 快 限制 被代理类不能是 ...

  5. 分布式id的方案

    1 简介 在分布式系统架构中,通常会涉及到分布式全局唯一ID的生成 在复杂分布式系统中,往往需要对大量的数据和消息进行唯一标识. 如在金融.电商.支付.等产品的系统中,数据日渐增长,对数据分库分表后需 ...

  6. WPF中使用LibVLCSharp.WPF 播放rtsp

    目录 LibVLCSharp.WPF简介 vlc:VideoView基本使用 安装LibVLC 播放rtsp 引入命名空间 xaml 代码 cs代码 截图 概述 代码示例 vlc:VideoView进 ...

  7. 【Go并发编程】Goroutine的基本使用

    goroutine是什么 goroutine即协程,使用go关键字开启一个协程异步执行代码. 注意,main函数也是个goroutine. 基本使用 使用go执行子任务,会交替执行(和时间片一样). ...

  8. python下载图片实现方法

    转载: https://www.jb51.net/article/119178.htm

  9. 跳板攻击之:reGeorg 代理转发

    跳板攻击之:reGeorg 代理转发 郑重声明: 本笔记编写目的只用于安全知识提升,并与更多人共享安全知识,切勿使用笔记中的技术进行违法活动,利用笔记中的技术造成的后果与作者本人无关.倡导维护网络安全 ...

  10. STM32L4 Keil ST-Link 连接失败

    ST-LINK 连接失败的因素,以我个人的经历而言有两种:一个是驱动问题,一个是插线问题.连接正常的情况如下图所示,SWDIO 能显示你的设备信息: 注意使用 SW 端口,JTAG 端口导致无法识别设 ...