数据备份:
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;