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) + ".sql";

		// ///以下是数据库信息

		// 数据库名称
		String dbname = "wm_advert";
		// 表名称
		String tablename = "wm_ad_location";
		// 数据库地址
		String dbhost = "10.0.0.254";
		// 数据库用户名
		String username = "wm_psql";
		// 数据库恢复用到的文件的名称
		String restorefilename = "20140426172335.sql";
		// 备份客户端的路径
		String dbpath = "C:\\Progra~1\\PostgreSQL\\9.3\\bin\\";
		// 备份下来的文件的完整路径
		String backuppath = "C:\\Users\\admin\\" + filename;
		// 恢复用到的文件的完成路径
		String restorepath = "C:\\Users\\admin\\" + restorefilename;

		// 数据库端口
		String dbport = "5432";

		//new Test().backupDB(dbname, tablename, username, backuppath, dbpath,
			//	dbhost, dbport);
		 new Test().restoreDB(dbname, username, restorepath, dbpath, dbhost,
		 dbport);
	}

	public boolean backupDB(String dbname, String tablename, String username,
			String backuppath, String dbpath, String dbhost, String dbport) {
		// 本地测试用
		// username = "postgres";
		// String dbpath = "C:\\Progra~1\\PostgreSQL\\9.3\\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(" -h ");
		cmdbuf.append(dbhost);
		cmdbuf.append(" -p ");
		cmdbuf.append(dbport);
		cmdbuf.append(" -f ");
		cmdbuf.append(backuppath);
		cmdbuf.append(" -E utf8 ");// 编码
		cmdbuf.append(" -t ");
		cmdbuf.append(tablename);
		cmdbuf.append(" ");
		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 restorepath, String dbpath, String dbhost, String dbport) {

		boolean flag = true;// 恢复是否成功
		Runtime rt = Runtime.getRuntime();// 得到jvm的运行环境
		Process process;
		StringBuffer cmdTemp = new StringBuffer();// 命令模版
		cmdTemp.append(dbpath);
		cmdTemp.append("psql -U ");// 用户名
		cmdTemp.append(username);
		cmdTemp.append(" -h ");
		cmdTemp.append(dbhost);
		cmdTemp.append(" -p ");
		cmdTemp.append(dbport);
		cmdTemp.append(" -d ");
		cmdTemp.append(dbname);
		cmdTemp.append(" -f ");
		cmdTemp.append(restorepath);

		try {
			System.out.println(cmdTemp);
			process = rt.exec(cmdTemp.toString());// 还原数据库
		} catch (Exception e) {
			flag = false;
			e.printStackTrace();
		}
		return flag;
	}
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值