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.lang.Runtime
Processexec(String command)
Executes the specified string command in a separate process.
调用oracle的exp/imp命令,命令的用法,百度吧,很多的
备份:发送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