java oracle数据备份_Java备份还原Oracle数据库
Java備份還原Oracle數據庫,不知道還有沒好點的方法 希望有的也能提供下方法或者代碼。
Java備份還原Oracle數據庫,,不知道還有沒好點的方法 希望有的也能提供下方法或者代碼。
package com.servlet.util;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.nio.ByteBuffer;
import java.nio.channels.Channels;
import java.nio.channels.FileChannel;
import java.nio.channels.ReadableByteChannel;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
/**
* 數據庫備份還原
* @author RootSuper
* @version 2012-11-12
*/
@SuppressWarnings("unused")
public class BackupOracleDatabase {
/** 用戶名 */
private String userName;
/** 密碼 */
private String userPass;
/** 服務地址 */
private String serverAddr;
/** 備份文件路徑 */
private String backupFilePath;
/** 備份日志路徑*/
private String logPath;
/**
* constructor
* @param userName 數據庫用戶名
* @param userPass 數據庫用戶密碼
* @param serverAddr? 服務地址:端口/數據庫名稱
* @param backupFilePath 備份文件路徑
*/
public BackupOracleDatabase(String Name, String Pass,
String Addr, String FilePath,String log) {
this.userName = Name;
this.userPass = Pass;
this.serverAddr = Addr;
this.backupFilePath = FilePath;
this.logPath = log;
}
/**
* 獲取命令串
* @param bool 是否為還原數據庫的命令串 默認為獲取備份命令
* @return commStr 命令串
*/
private String GetCommand(boolean bool){
String commStr = "EXP @USER@/@PASSWORD@@@SERVER@ FILE=@FILEPATH@ LOG=@LOGPATH@ FULL=Y";
if(bool){
commStr = "IMP @USER@/@PASSWORD@@@SERVER@ FILE=@FILEPATH@ LOG=@LOGPATH@ FULL=Y";
}
String temp = commStr.replaceAll("@USER@", this.userName).replaceAll("@PASSWORD@", this.userPass).replaceAll("@SERVER@", this.serverAddr).replaceAll("@FILEPATH@",this.backupFilePath).replaceAll("@LOGPATH@", this.logPath);
System.out.println(temp);
return temp;
}
/**
* 備份或者還原數據庫
* @param bool 真:還原數據庫? 假:備份數據庫
* @return boolean
*/
public boolean expBackup(boolean bool) {
Runtime rt = Runtime.getRuntime();
Process processexp = null;
try {
processexp = rt.exec(GetCommand(bool));
return true;
} catch (IOException e) {
e.printStackTrace();
}
return false;
}
}
總結
以上是生活随笔為你收集整理的java oracle数据备份_Java备份还原Oracle数据库的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 中行信用卡余额转出收手续费吗
- 下一篇: 陕西煤业是国企还是私企