欢迎投稿

今日深度:

Java实现Oracle数据库备份,oracle数据库备份

Java实现Oracle数据库备份,oracle数据库备份


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

import java.io.File;
import java.io.IOException;

/**
 * Oracle数据库备份
 * 
 * @author GaoHuanjie
 */
public class OracleDatabaseBackup {

	/**
	 * Java代码实现Oracle数据库导出
	 * 
	 * @author GaoHuanjie
	 * @param userName 进入数据库所需要的用户名
	 * @param password 进入数据库所需要的密码
	 * @param SID 用户所在的SID
	 * @param savePath 数据库导出文件保存路径
	 * @param fileName 数据库导出文件文件名
	 * @return 返回true表示导出成功,否则返回false。
	 */
	public static boolean exportDatabaseTool(String userName, String password, String SID, String savePath, String fileName) throws InterruptedException {
		File saveFile = new File(savePath);
		if (!saveFile.exists()) {// 如果目录不存在
			saveFile.mkdirs();// 创建文件夹
		}
		try {
			Process process = Runtime.getRuntime().exec("exp " + userName + "/" + password + "@" + SID + " file=" + savePath + "/" + fileName + ".dmp");
			if(process.waitFor() == 0){//0 表示线程正常终止。 
				return true;
			}
		} catch (IOException e) {
			e.printStackTrace();
		}
		return false;
	}

	public static void main(String[] args) throws InterruptedException {
		if (exportDatabaseTool("gaohuanjie", "ab19890110", "orcl", "d:/BackupDatabase", "oracledb")) {
			System.out.println("数据库成功备份!!!");
		} else {
			System.out.println("数据库备份失败!!!");
		}
	}
}


问各位:怎使用java实现Oracle数据库的备份

java.lang.Runtime

Processexec(String command)

Executes the specified string command in a separate process.

调用oracle的exp/imp命令,命令的用法,百度吧,很多的
 

用java代码实现Oracle数据库的备份与恢复(保存为dmp或sql)

备份:发送sql给mssqlserver:
backup database <your database name> to disk='备份文件名' with init
注意: 1.备份文件名必须为绝对路径,
2.备份文件只能是mssqlserver所在的机器上的路径, mssql支持备份到网络位置。

恢复:
restore database <your database name> from disk='备份文件名' with replace
要注意的是执行restore database时,要恢复的数据库必须没有任何客户端连接,包括自身(发起restore database命令的连接)。发使用restore,可以连接到master库,然后再发送restore命令。
否则,一定失败。

在jsp中如何用呢
-------------------------------------------------------------------------------------- 你用这个了!
<%
先要连接上Connection对象!
就是要先和数据库建立起连接
然后在jsp页面中直接用我这样的语句就可以了
try{
String sql="backup database xncsims to disk='d:\\xncback.dat'";

st=con.createStatement();

rs=st.executeQuery(sql);

}
catch(SQLException e){ System.out.println(e.toString());}
catch(Exception e){ System.out.println(e.toString());}

%>

rs=st.executeQuery(sql);
这里就是把你的SQL语句发到数据库执行

另有一篇论文供参考
www.cqvip.com/...117188
 

www.htsjk.Com true http://www.htsjk.com/shujukunews/2670.html NewsArticle Java实现Oracle数据库备份,oracle数据库备份 今天将很早就实现的一个Oracle数据库备份功能粘贴出来,这个功能是在大学做阶段设计时写的: import java.io.File;import java.io.IOException;/** * Orac...
评论暂时关闭