Linux系统下,Oracle数据库的备份与还原

数据备份:


1.使用Linux系统下的数据库管理员账号连接linux终端。


2. 执行以下语句,创建“bak_dir”文件夹。

 mkdir bak_dir


3. 执行以下语句,为“bak_dir”文件夹赋予读、写和执行权限。

 chmod 777 bak_dir


4. 执行以下语句,以sysdba用户登录Oracle数据库服务器。

 sqlplus 数据库管理员账号/密码@数据库实例名 as sysdba


5. 执行以下语句,将“bak_dir”指定为“/opt/oracle/bak_dir”。
 create or replace directory bak_dir as '/opt/oracle/bak_dir'

 commit


6. 执行以下语句,将“bak_dir”的读、写和执行权限赋给xx(数据用户名)用户。
 grant all on directory bak_dir to xx


 commit
7. 执行以下语句,退出oracle数据库服务器。
 quit


执行以下语句,将sysdb用户的表备份到“bak_dir”目录下。
8.expdp xx(要导出表所在的数据库用户名)/xx(密码)@数据库实例名 directory=bak_dir dumpfile=expdb_xx.dmp logfile=expdb_xxlog tables=表名


 


数据还原:


1.在命令行输入:sqlplus "/as sysdba"


2. 执行以下语句登录xx数据库,用户名:xx,密码:xx(请输入当地实际密码)
 conn xx/xx;


3.如果恢复的表中有涉及到触发器的请停止触发器,例:A表


alter table A disable all triggers; 


commit;


4. 执行以下语句退出当前用户

 quit;


5. 执行以下语句,恢复用户数据。
 impdp xx/xx@数据库实例名 directory=bak_dir table_exists_action=truncate dumpfile=expdb_xx.dmp logfile=impdb_xx.log


5.在命令行输入:sqlplus "/as sysdba"


6. 执行以下语句登录xx数据库,用户名:xx,密码:xx(请输入当地实际密码)
 conn xx/xx;


7. 执行以下语句打开被禁止的触发器


alter table A enable all triggers;


commit;

你可能感兴趣的:(mysql&oracle)