java对mysql数据库进行单表筛选备份、还原操作
最近在做的一个项目需要对mysql数据库中的单个表格进行备份
其中,一部分表格需要进行筛选备份(例如对最近插入的1000条记录进行备份)
思路:java调用系统命令完成备份操作
假设现在有数据库testdb
其中有数据表test_table
备份操作所做的是,把指定的数据库表中的一部分记录生成一个sql备份文件,以供还原操作,文件名使用日期生成。
备份操作
public void backUpTable(String tableName, Integer number) throws Exception {
StringBuilder command = new StringBuilder();
Runtime rt = Runtime.getRuntime();
Process pro = null; command.append("mysqldump -u" + username + " -p" + password + " testdb ");
//username为数据库用户名 password为密码
String time = new SimpleDateFormat("yyyy-MM-dd_HH-mm-ss").format(new Date());
String fileName ="E://" + tableName + "/" + time + ".sql";//放在E盘下
//备份表中最新number行的数据
// mysqldump -uusername -ppassword testdb test_table -w \" 1=1 ORDER BY id DESC LIMIT 0,300\" --result-file=E://test.sql
command.append(tableName);
command.append(" ");
command.append("-w \" 1=1 ORDER BY id DESC LIMIT 0,");
command.append(number);
command.append("\"");
command.append(" ");
command.append("--result-file=" + fileName);
pro = rt.exec(command.toString()); //命令执行出错则打印相关错误信息
BufferedReader br = new BufferedReader(new InputStreamReader( pro.getErrorStream()));
String errorLine = null;
while ((errorLine = br.readLine()) != null) {
System.out.println(errorLine);
}
br.close();
}
其中,使用mysqldump进行备份操作
由于需要进行筛选,使用-w添加了筛选条件,--result-file= 指向生成文件的存放路径
备份完成了,接下来就是还原操作
假如我们需要将E://test.sql还原到数据库中,
需要执行的命令为mysql -uusername -ppassword testdb < E://test.sql
如果使用此命令,则涉及到了重定向符>,
而java无法识别重定向符和管道操作符,故不能向上面备份操作一样进行还原,需要采用其他方式,如下
在类中定义了字符串数组String[] command = new String[3];
1、需要先判断当前系统环境
public void initOSCommand(){
String osName = System.getProperty("os.name");
logger.info("系统环境为:" + osName);
osName = osName.toLowerCase();
if(osName.indexOf("win")>-1){
command[0] = "cmd";
command[1] = "/c";
}else if(osName.indexOf("linux")>-1){
command[0] = "/bin/bash";
// command[0] = "/bin/sh"; sh和bash的区别不大,bash是sh的增强版本
command[1] = "-c";
}else{
logger.error("当前系统环境不支持数据库还原操作");
}
}
2、执行还原操作
public void restoreTable()throws Exception {
//mysql -uusername -ppassword testdb < E://test.sql
StringBuilder commandStr = new StringBuilder();
Runtime rt = Runtime.getRuntime();
Process pro = null;
String fileName = "E://test.sql"; commandStr.append("mysql -u" + username + " -p" + password + " testdb < ");
commandStr.append(fileName);
command[2] = commandStr.toString();
// System.out.println(command[0] + command[1] + command[2]);
pro = rt.exec(command); // 命令执行出错则打印相关错误信息
BufferedReader br = new BufferedReader(new InputStreamReader( pro.getErrorStream()));
String errorLine = null;
while ((errorLine = br.readLine()) != null) {
System.out.println(errorLine);
}
br.close();
}
以上为解决方法中的一种,另一种等测试完可行之后再贴上来。
以上代码在window10下能正常运行,尚未在linux上测试,后面测试完了再更新此随笔。
需要特别注意的是,mysql5.6版本以后,执行mysqldump -uusername -ppassword ····
会无法执行并提示安全警告
解决方法:对mysqldump命令进行配置(详情百度2333)或降低mysql的版本到5.6以下
个人能力渣渣,随笔有不对或者讲述的不到位的地方,求读者指点批判,谢谢阅读
java对mysql数据库进行单表筛选备份、还原操作的更多相关文章
- MySQL数据库之单表查询中关键字的执行顺序
目录 MySQL数据库之单表查询中关键字的执行顺序 1 语法顺序 2 执行顺序 3 关键字使用语法 MySQL数据库之单表查询中关键字的执行顺序 1 语法顺序 select distinct from ...
- MySQL数据库语法-单表查询练习
MySQL数据库语法-单表查询练习 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客主要是对聚合函数和分组的练习. 一.数据表和测试数据准备 /* @author :yinz ...
- mysql数据库之单表查询多表查询
单表查询 前期表准备 create table emp( id int not null unique auto_increment, name varchar(20) not null, sex e ...
- mysql数据库之单表查询
单标查询 单表查询语句 关键字执行的优先级 简单查询 where约束 group by 聚合函数 HAVING过滤 order by 查询排序 LIMIT限制查询的记录数 使用正则表达式查询 单表查询 ...
- 基于MySql数据库的单表与多表联合查询
这里以学生 班级 身份证 以及课程为例 1,启动MySql数据库 开启服务 2.1.0新建一张班级表 备注:CHARSET = UTF8 (指定编码格式为utf8 防止中文乱码) /*班级表*/ C ...
- JAVA 操作远程mysql数据库实现单表增删改查操作
package MysqlTest; import java.sql.DriverManager; import java.sql.ResultSet; import com.mysql.jdbc.C ...
- MySql数据库之单表数据查询
查询数据 1.查询所有数据: select * from 表名; 2.根据指定条件查询数据:
- Java基础-MySQL数据库扫盲篇
Java基础-MySQL数据库扫盲篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.数据库概述 1>.什么是数据库 数据库就是存储数据的仓库,其本质是一个文件系统,数据按 ...
- 点评阿里JAVA手册之MySQL数据库 (建表规约、索引规约、SQL语句、ORM映射)
下载原版阿里JAVA开发手册 [阿里巴巴Java开发手册v1.2.0] 本文主要是对照阿里开发手册,注释自己在工作中运用情况. 本文内容:MySQL数据库 (建表规约.索引规约.SQL语句.ORM映 ...
随机推荐
- AsyncCalls – Asynchronous function calls
AsyncCalls – Asynchronous function callsWith AsyncCalls you can execute multiple functions at the sa ...
- mt7601 driver
http://download.csdn.net/detail/u011500307/7011649 http://my.oschina.net/fgq611/blog/180750 http://b ...
- N-Queens II——Leetcode
Follow up for N-Queens problem. Now, instead outputting board configurations, return the total numbe ...
- Merge Intervals——LeetCode
Given a collection of intervals, merge all overlapping intervals. For example,Given [1,3],[2,6],[8,1 ...
- winscp自动执行脚本
我们经常使用WinSCP工具通过sftp协议上传获取文件,本文描述通过bat批量处理文件. 首先,我们打开dos命令窗口使用 cd \d :D\WinSCP 打开WinSCP安装目录 上传文件: wi ...
- drp用户管理完成后,asp.net与java的一个简单比较
DRP视频断断续续看了有一个月的时间了,跟着视频进行,从需求到设计,到现在的编码实现,跟之前用asp.net做系统步调一致,都遵守软件设计的规范,一步步来进行.尤其是编码实现,越来越感觉java与as ...
- lyGrid表格插件
表格基础参数: grid = lyGrid({ l_column : [{//表格列表数据 colkey : null, ...
- kafka单机安装配置
1.下载kafka wget https://www.apache.org/dyn/closer.cgi?path=/kafka/0.8.2.1/kafka_2.9.2-0.8.2.1.tgz 2.解 ...
- 理解Android的startservice和bindservice(转)
一.首先,让我们确认下什么是service? service就是android系统中的服务,它有这么几个特点:它无法与用户直接进行交互.它必须由用户或者其他程序显式的启动.它的优先级比较高,它比处于前 ...
- Swift3.0已出坑-适配iOS10,项目迁移Swift3.0问题总结。
http://www.jianshu.com/p/27fd2a2b32e4 Yes表示swift版本为2.3 NO表示swift版本为3.0