Java实现Oracle数据库备份

时间:2023-03-09 16:10:12
Java实现Oracle数据库备份

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

  1. import java.io.File;
  2. import java.io.IOException;
  3. /**
  4. * Oracle数据库备份
  5. *
  6. * @author GaoHuanjie
  7. */
  8. public class OracleDatabaseBackup {
  9. /**
  10. * Java代码实现Oracle数据库导出
  11. *
  12. * @author GaoHuanjie
  13. * @param userName 进入数据库所需要的用户名
  14. * @param password 进入数据库所需要的密码
  15. * @param SID 用户所在的SID
  16. * @param savePath 数据库导出文件保存路径
  17. * @param fileName 数据库导出文件文件名
  18. * @return 返回true表示导出成功,否则返回false。
  19. */
  20. public static boolean exportDatabaseTool(String userName, String password, String SID, String savePath, String fileName) throws InterruptedException {
  21. File saveFile = new File(savePath);
  22. if (!saveFile.exists()) {// 如果目录不存在
  23. saveFile.mkdirs();// 创建文件夹
  24. }
  25. try {
  26. Process process = Runtime.getRuntime().exec("exp " + userName + "/" + password + "@" + SID + " file=" + savePath + "/" + fileName + ".dmp");
  27. if(process.waitFor() == 0){//0 表示线程正常终止。
  28. return true;
  29. }
  30. } catch (IOException e) {
  31. e.printStackTrace();
  32. }
  33. return false;
  34. }
  35. public static void main(String[] args) throws InterruptedException {
  36. if (exportDatabaseTool("gaohuanjie", "ab19890110", "orcl", "d:/BackupDatabase", "oracledb")) {
  37. System.out.println("数据库成功备份!!!");
  38. } else {
  39. System.out.println("数据库备份失败!!!");
  40. }
  41. }
  42. }