设计到几个方面:
1、java 执行 linux 或windows命令
2、数据库备份还原命令
3、postgresql 备份还原命令 没有密码参数,目前仅程序与数据库在同一服务器上执行通过。
import java.text.SimpleDateFormat;
import java.util.Date;
public class Test {
public static void main(String[] args) {
Date d = new Date(); // 备份文件名称
SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");
String filename = sdf.format(d) + ".tar";
String dbname = "ipam";
String username = "postgres";
String dbpath = "d:\\Program Files\\PostgreSQL\\9.1\\bin\\";
String backuppath = "d:\\" + filename;
// new Test().backupDB(dbname, username, backuppath, dbpath);
backuppath = "d:\\20120826095554.tar";
new Test().restoreDB(dbname, username, backuppath, dbpath);
}
public boolean backupDB(String dbname, String username, String backuppath,
String dbpath) {
// 本地测试用
// username = "postgres";
// String dbpath = "d:\\Program Files\\PostgreSQL\\9.1\\bin\\";
boolean flag = true;// 备份是否成功
Runtime rt = Runtime.getRuntime();// 得到jvm的运行环境
Process process;
StringBuffer cmdbuf = new StringBuffer();
cmdbuf.append(dbpath);
cmdbuf.append("pg_dump -U ");// 用户名
cmdbuf.append(username);
cmdbuf.append(" -f ");
cmdbuf.append(backuppath);
cmdbuf.append(" -E utf8 ");// 编码
cmdbuf.append(" -Ft ");
cmdbuf.append(dbname);
try {
// 调用 cmd:
System.out.println(cmdbuf);
process = rt.exec(cmdbuf.toString());
} catch (Exception e) {
flag = false;
e.printStackTrace();
}
return flag;
}
public boolean restoreDB(String dbname, String username, String backuppath,
String dbpath) {
boolean flag = true;// 恢复是否成功
Runtime rt = Runtime.getRuntime();// 得到jvm的运行环境
Process process;
StringBuffer cmdTemp = new StringBuffer();// 命令模版
cmdTemp.append(dbpath);
cmdTemp.append("pg_restore -U ");
cmdTemp.append(username);
cmdTemp.append(" -c -d ");
cmdTemp.append(" " + dbname + " ");
cmdTemp.append(backuppath);
try {
process = rt.exec(cmdTemp.toString());// 还原数据库
} catch (Exception e) {
flag = false;
e.printStackTrace();
}
return flag;
}
}
————————————————
java 备份、还原postgresql数据库
转载本文章为转载内容,我们尊重原作者对文章享有的著作权。如有内容错误或侵权问题,欢迎原作者联系我们进行内容更正或删除文章。
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
PostgreSQL 数据库导入导出操作
postgreSQL 数据库日常备份恢复操作,如果数据库数据在备份恢复操作过程中有变化可能需要多次备份,以保证数据完整性
postgreSQL pg_dump pg_restore -
dbeaver 导出postgresql 设置版本 dbeaver导出数据库表
一起来学matlab-matlab学习笔记4参考书籍 《matlab 程序设计与综合应用》张德丰等著 感谢张老师的书籍,让我领略到matlab的便捷MATLAB提供了将磁盘文件或剪贴板中的数据加载到工作空间的多种方法,称之为导入数据(ImportingData);同时也提供了多种将工作空间的变量保存到磁盘的方法,称之为导出数据(ExportingData).选择不同的导入机制或导出机制取决于要传输
dbeaver导出表结构 dll导出结构体 exp 导出表 除了某些个表 grafana导入json文件没有数据 java读取文件实现导出功能