[20180419]关于闪回的一些问题.txt

简介: [20180419]关于闪回的一些问题.txt --//别人问的问题,就是drop表,然后flashbask表,建立的触发器还在吗? --//我记忆里触发器应该还在,我个人喜欢通过例子验证自己的判断.

[20180419]关于闪回的一些问题.txt

--//别人问的问题,就是drop表,然后flashbask表,建立的触发器还在吗?
--//我记忆里触发器应该还在,我个人喜欢通过例子验证自己的判断..

1.环境:
SCOTT@test01p> @ ver1
PORT_STRING          VERSION    BANNER                                                                       CON_ID
-------------------- ---------- ---------------------------------------------------------------------------- ------
IBMPC/WIN_NT64-9.1.0 12.1.0.1.0 Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production      0

create table t as select rownum id from dual connect by level<=10;
create or replace trigger tri_t_insert
before insert on t
for each row
begin
  null;
end;
/

2.测试:
SCOTT@test01p> drop table t ;
Table dropped.

SCOTT@test01p> flashback table t to before drop ;
Flashback complete.

SCOTT@test01p> select TRIGGER_BODY c40,TRIGGER_NAME from user_triggers where table_name='T';
C40                                      TRIGGER_NAME
---------------------------------------- --------------------
begin                                    BIN$iU6Cl+FuSHqfYa5L
  null;                                  2EGWOA==$0
end;

--//说明还在.仅仅名字修改了

3.自然会想到还有什么情况会导致恢复后丢失什么信息.
--//看看约束的情况.

SCOTT@test01p> drop trigger "BIN$iU6Cl+FuSHqfYa5L2EGWOA==$0";
Trigger dropped.

SCOTT@test01p> alter table t add ( constraint ck_id check (id<11) enable validate);
Table altered.

SCOTT@test01p> insert into t values(11);
insert into t values(11)
*
ERROR at line 1:
ORA-02290: check constraint (SCOTT.CK_ID) violated

SCOTT@test01p> drop table t ;
Table dropped.

SCOTT@test01p> flashback table t to before drop ;
Flashback complete.

SCOTT@test01p> insert into t values(11);
insert into t values(11)
*
ERROR at line 1:
ORA-02290: check constraint (SCOTT.BIN$bTSE9Rx6RLqZwAKVKwrnaw==$0) violated

--//约束还在,仅仅名字改了.

4.测试主外键的情况:
create table p ( x int primary key );
create table c ( x references p );
insert into p values ( 1 );
insert into p values ( 2 );
commit;

SCOTT@test01p> insert into c values ( 3 );
insert into c values ( 3 )
*
ERROR at line 1:
ORA-02291: integrity constraint (SCOTT.SYS_C0011491) violated - parent key not found

SCOTT@test01p> drop table c ;
Table dropped.

SCOTT@test01p> flashback table c to before drop ;
Flashback complete.

SCOTT@test01p> insert into c values ( 3 );
1 row created.

--//^_^,主外键约束丢失.

5.12c可以支持表中使用seq,链接:http://blog.itpub.net/267265/viewspace-767751/

SCOTT@test01p> drop table t purge ;
Table dropped.

create table t
(
id number GENERATED ALWAYS as identity ( start with 1 increment by 1),
name varchar2(10)
);

insert into t (name) values('a');
commit ;

SCOTT@test01p> select * from t;
        ID NAME
---------- --------------------
         1 a

SCOTT@test01p> drop table t ;

Table dropped.

SCOTT@test01p> flashback table t to before drop ;
Flashback complete.        

SCOTT@test01p> select * from t;
        ID NAME
---------- --------------------
         1 a
         2 b
--//没有问题.现在看来仅仅在主外键定义上丢失.
--//可以发现oracle设计时考虑问题的周到,因为drop c表后如果p表dml操作导致主外键的依赖可能失效,
--//比如delete from p where x=1.这样即使闪回c表可能主外键的依赖也破坏,恢复时去掉主外键约束.

目录
相关文章
|
Oracle 关系型数据库 Linux
[20171208]rman与truncate3.txt
[20171208]rman与truncate3.txt --//前几天测试truncate表依旧备份一部分信息,测试几次确定备份8extent.当时的测试几个extents是相邻的.
889 0
|
监控 Oracle 关系型数据库
[20171208]强制删除归档日志文件.txt
[20171208]强制删除归档日志文件.txt --//测试环境,产生日志太多,想强制删除. RMAN> delete archivelog all ; released channel: ORA_DISK_1 allocated channel: ORA...
1428 0
|
Oracle 关系型数据库 Linux
[20171206]rman与truncate2.txt
[20171206]rman与truncate2.txt --//上午测试发现truncate的表在做rman备份时还要做8个extents的备份. --//不知道自己的猜测是否正确,选择一个使用UNIFORM SIZE 的表空间测试看看.
1072 0
|
Oracle 关系型数据库 测试技术
[20171206]rman与truncate.txt
[20171206]rman与truncate.txt --//昨天下班在回家的路上,突然想起以前遇到的问题,就是truncate表后,rman做备份时会备份多少truncate表的信息, --//当时在itpub上,还存在讨论,就是rman会备份空block吗?参考链接:http://www.
998 0
|
Oracle 关系型数据库 数据库
[20171122]恢复数据文件块头5.txt
[20171122]恢复数据文件块头5.txt --//前几天做了恢复数据文件块头,通过备份文件直接取出文件块头,覆盖原来的数据块,然后修复. --//今天测试使用image copy来恢复.
1120 0
|
关系型数据库 Linux 数据库
[20171116]11GR2控制文件自动备份.txt
20171116]11GR2控制文件自动备份.txt SYS@book> @ &r/ver1 PORT_STRING                    VERSION        BANNER ---------------------------...
956 0
|
Oracle 关系型数据库 数据库
[20171114]恢复数据文件块头2.txt
[20171114]恢复数据文件块头2.txt --//曾经写过一篇[20161111]数据库文件头的修复.txt,但是利用大小相似的数据文件头覆盖来恢复,那是属于特种恢复.
1079 0
|
SQL Oracle 关系型数据库
[20170627]使用TSPITR恢复表空间.txt
[20170627]使用TSPITR恢复表空间.txt --//RMAN提供了一种实现所谓TSPITR(Tablespace Point-In-Time Recovery)的技术,通过简单的一个语句,就可以在主库不停库(很吸引人) --//的情况下,利用备份集和连续的归档日志,实现表空间级别的定点恢复。
896 0
|
监控 Oracle 关系型数据库
[20170203]关于flashback的问题.txt
[20170203]关于flashback的问题.txt --今天生产系统遇到的问题,dataguard机器磁盘空间不足,需要释放磁盘空间,无论如何删除日志,空间回收都是很少.
894 0
|
Oracle 关系型数据库 Linux
[20161212]备份archivelog.txt
[20161212]备份archivelog.txt --许多人都知道如果执行backup database plus archivelog;实际上是先执行如下: 1.
728 0