一、undo_retention参数的查询、修改:用
show parameter undo;命令查看当时的数据库参数undo_retention设置。显示如下:undo_management string AUTO
undo_retention integer
10800undo_suppress_errors boolean FALSE
undo_tablespace string UNDOTBS1undo_retention(保持力),10800单位是秒。即3个小时。修改默认的undo_retention参数设置:
ALTER SYSTEM SET undo_retention=10800 SCOPE=BOTH;二、Oracle误删除表数据后的的快速回复功能方法:【方法一】:
通过oracle提供的回闪功能:
exec dbms_flashback.enable_at_time(to_date("2007-07-23 10:21:00","yyyy-mm-dd hh24:mi:ss"));set serveroutput on
DECLARE r_temp hr.job_history%ROWTYPE;
CURSOR c_temp IS SELECT * FROM hr.job_history;
BEGIN
OPEN c_temp;
dbms_flashback.disable;
LOOP
FETCH c_temp INTO r_temp;
EXIT WHEN c_temp%NOTFOUND;
insert into hr.job_history(EMPLOYEE_ID,JOB_ID,START_DATE,END_DATE) values (r_temp.EMPLOYEE_ID,r_temp.JOB_ID,r_temp.START_DATE,r_temp.END_DATE);
commit;
END LOOP;
CLOSE c_temp;
END;
这种办法可以将删除的数据回复到对应的表中,首先要保证该用户有执行dbms_flashback包的权限【方法二】:
insert into hr.job_history
select * from hr.job_history as of timestamp to_timestamp("2007-07-23 10:20:00", "yyyy-mm-dd hh24:mi:ss");这种方法简单,容易掌握,功能和上面的一样时间为你误操作之前的时间,最好是离误操作比较近的,因为oracle保存在回滚保持段里的数据时间有一定的时间限制由undo_retention 这个参数值决定。Oralce定时执行存储过程任务设置步骤详细SQL与Oracle的外键约束之级联删除篇相关资讯 数据库 Oracle数据库 Oracle入门教程 oracle数据库教程
- Oracle数据库全球化 (03月01日)
- Oracle数据库日期过滤方法性能比较 (02/02/2015 13:20:26)
- Oracle数据库安装中端口被占用问题 (10/29/2014 07:42:24)
| - 在CentOS 6.6上搭建C++运行环境并 (10/10/2015 19:44:40)
- Oracle数据库无法使用localhost和 (11/14/2014 16:39:10)
- 使用SQLT来构建Oracle测试用例 (08/28/2014 06:17:41)
|
本文评论 查看全部评论 (0)