1. 程式人生 > >oracle資料庫定時備份及還原方法

oracle資料庫定時備份及還原方法

一、oracle資料備份

1、找到電腦右下方開始--執行,輸入cmd,進入dos命令視窗。

2、輸入sqlplus system/密碼@orcl (一般管理員登入)--------連線本機oracle資料庫

輸入 sqlplus system/密碼@IP:埠/orcl (一般管理員登入)--------連線非本機oracle資料庫

3、建立一個dmp的目錄,輸入create directory dpdata1 as 'E:\temp\dmp'; 

4、查詢是否有此目錄,select * from dba_directories;

5、在E盤下新建E:\temp\dmp目錄

6、賦於要匯出資料表的所屬使用者許可權,grant read,write on directory dpdata1 to 使用者名稱;,授權成功以後輸入exit 退出sql。

7、開始資料備份,expdp system/密碼@orcl directory=dpdata1 dumpfile=檔名.dmp logfile=檔名.log schemas=使用者名稱

8、目錄E:\temp\dmp下面可以看到備份檔案,備份完成。

二、oracle資料還原

1、找到電腦右下方開始--執行,輸入cmd,進入dos命令視窗。

2、輸入sqlplus system/密碼@orcl (一般管理員登入)--------連線本機oracle資料庫

3、刪除user,輸入 drop user 使用者名稱 cascade;

4、匯入還原資料,輸入 impdp system/密碼@orcl directory=dpdata1 dumpfile=dmp檔名 logfile=log檔名 schemas=使用者名稱;        還原完成。

5、在plsql或者其他oracle檢查資料完整性,指令碼如下:

select t.table_name , t.num_rows from user_tables t order by t.num_rows desc

三、定時備份及壓縮

1.備份及壓縮

@echo off

set backupfile=f_database_%date:~0,4%-%date:~5,2%-%date:~8,2%.dmp
set logfile=f_database_%date:~0,4%-%date:~5,2%-%date:~8,2%.log

delete 1days files

forfiles /p "E:\temp\dmp" /d -1  /c "cmd /c echo deleting @file ... && del /f @path"

cd F:\temp\dmp

backup schemas
set backupfile=IRRIG_SOUTH_DEV_%date:~0,4%-%date:~5,2%-%date:~8,2%.dmp
set logfile=IRRIG_SOUTH_DEV_%date:~0,4%-%date:~5,2%-%date:~8,2%.log
expdp IRRIG_SOUTH_DEV/
[email protected]
directory=dpdata1 dumpfile=%backupfile% logfile=%logfile% schemas=IRRIG_SOUTH_DEV parallel=4 rem 壓縮程式目錄 set zipDir= C:\Program Files (x86)\HaoZip\HaoZip.exe echo 正在設定壓縮包日期... set mydate=%date:~5,2%%date:~8,2% echo 正在壓縮... %zipDir% a -m5 -t %bakDir%\ora_data_%mydate%.zip %bakDir%\ora_data_%mydate%.dmp %bakDir%\ora_log_%mydate%.log

2.定時備份

@ECHO OFF
schtasks /create /tn IRRIG_SOUTH_DEV資料庫定時備份 /tr "E:\temp\IRRIG_SOUTH_DEV.bat" /sc daily /st 00:00:00 /ru "system" 
PAUSE
EXIT
windows每晚自動執行資料庫備份bat