【Oracle】回收站
☆回收站概念
oracle从10g开始,引入回收站(Recycle Bin)概念。回收站的全称叫:Tablespace Recycle Bin。回收站是一个逻辑区域,oracle并没有为它分配物理空间。当表被Drop后,如果回收站中空间够用的话,表并没有被立即删除,oracle会给表加上一个被删除的标记。只有当回收站空间不足,或者手动清理回收站,这些被删除的表才会被彻底删除。所以当我们误删除以后,可以用闪回技术还原被删除的表。
☆开启、关闭回收站
可以使用命令查看数据库是否开启了回收站,当下列中的value值为on时表明开启,off表示关闭
SYS@LGR> show parameter recyclebin; NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
recyclebin string on SYS@LGR> select name,value from v$parameter where name='recyclebin'; NAME VALUE
-------------------- ----------
recyclebin on
☆可以通过设置初始化参数recyclebin启用或者禁用回收站功能。
##会话级别关闭回收站
SYS@LGR> ALTER SESSION SET RECYCLEBIN=OFF;
Session altered.
##系统级别关闭回收站
SQL> alter system set recyclebin = off scope = spfile;
System altered.
☆闪回删除
语法:
FLASHBACK TABLE [schema.] {BEFORE DROP [RENAME TO
table_new_name]}
回收站中表名的含义:(格式:BINglobalUIDversion )
- BIN:表示 RECYCLEBIN
- globalUID:是一个全局唯一的,24 个字节,该标识与原对象名没有 任何关系
- version:指数据库分配的版本号
1) 表准备环境(创建测试表 t ,索引 idx_t ,触发器 trg_t)
SYS@LGR> conn scott/tiger;
Connected.
SCOTT@LGR> create table t(x number(2),d date); Table created. SCOTT@LGR> create unique index idx_t on t(x); Index created. SCOTT@LGR> create or replace trigger trg_t
2 before insert on t
3 for each row
4 begin
5 if :new.d is null then
6 :new.d :=sysdate;
7 end if;
8 end;
9 / Trigger created
2)删除表t
SCOTT@LGR> drop table t; Table dropped. SCOTT@LGR> select tname,tabtype from tab; TNAME TABTYPE
------------------------------ -------
BIN$Q8N67S/xGAngUwEAAH9JoA==$0 TABLE
BIN$QyLhuF3CKuHgUwEAAH/Q8Q==$0 TABLE
BONUS TABLE
DEPT TABLE
EMP TABLE
EMP1 TABLE
EMP2 TABLE
SALGRADE TABLE
T1 TABLE
TMPD_DEPT TABLE
TMPP_DEPT TABLE 11 rows selected. SCOTT@LGR> show recyclebin;
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
DEPT1 BIN$QyLhuF3CKuHgUwEAAH/Q8Q==$0 TABLE 2016-12-08:17:01:23
T BIN$Q8N67S/xGAngUwEAAH9JoA==$0 TABLE 2016-12-16:16:37:28 SCOTT@LGR> SELECT original_name, object_name, type,droptime FROM
2 user_recyclebin; ORIGINAL_NAME OBJECT_NAME TYPE DROPTIME
-------------- ------------------------------ -------- -------------------
IDX_T BIN$Q8N67S/vGAngUwEAAH9JoA==$0 INDEX 2016-12-16:16:37:28
DEPT1 BIN$QyLhuF3CKuHgUwEAAH/Q8Q==$0 TABLE 2016-12-08:17:01:23
TRG_T BIN$Q8N67S/wGAngUwEAAH9JoA==$0 TRIGGER 2016-12-16:16:37:28
T BIN$Q8N67S/xGAngUwEAAH9JoA==$0 TABLE 2016-12-16:16:37:28
3)闪回表
SCOTT@LGR> flashback table t to before drop; Flashback complete. SCOTT@LGR> SELECT original_name, object_name, type,droptime FROM user_recyclebin; ORIGINAL_NAME OBJECT_NAME TYPE DROPTIME
-------------------------------- ------------------------------ ------------------------- -------------------
DEPT1 BIN$QyLhuF3CKuHgUwEAAH/Q8Q==$0 TABLE 2016-12-08:17:01:23
4)查看闪回的表相关对象的状态
通过以下查询,发现以下两个问题:
1 :触发器的状态为失效的
2:对象名称,除表名以外,其他的都已不是原来的名称
SCOTT@LGR> SELECT object_name,object_type,status FROM user_objects; OBJECT_NAME OBJECT_TYPE STATUS
-------------------------------- ------------------- -------
DEPT TABLE VALID
PK_DEPT INDEX VALID
BONUS TABLE VALID
SALGRADE TABLE VALID
EMP1 TABLE VALID
EMP2 TABLE VALID
T1 TABLE VALID
TMPD_DEPT TABLE VALID
EMP TABLE VALID
TMPP_DEPT TABLE VALID
T TABLE VALID
BIN$Q8N67S/wGAngUwEAAH9JoA==$0 TRIGGER INVALID
BIN$Q8N67S/vGAngUwEAAH9JoA==$0 INDEX VALID
5) 重新编译触发器,并 重命名触发器
SCOTT@LGR> alter trigger"BIN$Q8N67S/wGAngUwEAAH9JoA==$0" compile; Trigger altered. SCOTT@LGR> alter trigger"BIN$Q8N67S/wGAngUwEAAH9JoA==$0" rename to trg_t; Trigger altered. SCOTT@LGR> SELECT object_name,object_type,status FROM user_objects; OBJECT_NAME OBJECT_TYPE STATUS
------------------------------ ------------------- -------
DEPT TABLE VALID
PK_DEPT INDEX VALID
BONUS TABLE VALID
SALGRADE TABLE VALID
EMP1 TABLE VALID
EMP2 TABLE VALID
T1 TABLE VALID
TMPD_DEPT TABLE VALID
EMP TABLE VALID
TMPP_DEPT TABLE VALID
T TABLE VALID
BIN$Q8N67S/vGAngUwEAAH9JoA==$0 INDEX VALID
TRG_T TRIGGER VALID
【Oracle】回收站的更多相关文章
- ORACLE 回收站导致的故障
ORACLE 回收站导致的故障 一.故障 (1)现象 一个生产环境,oracle数据库挂死,严重影响生产.查死锁sql,发现大量日志插入语句,并且每条运行时间都超过一分钟,插入非常缓慢.据分析 ...
- oracle 回收站管理
oracle10g,在pl/sql中选中删除后会出现类似:BIN$nJ5JuP9cQmqPaArFei384g==$0的表. 1.查看回收站 select * from user_recyclebin ...
- oracle 回收站
oracle10g,在pl/sql中选中删除后会出现类似:BIN$nJ5JuP9cQmqPaArFei384g==$0的表. 1.查看回收站 select * from user_recyclebin ...
- 5.创建表,使用alter进行表信息的增删改,Oracle回收站,集合运算
1 Oracle基于用户的管理方案 2 DDL语句可以管理数据库的对象有:视图 索引 序列 同义词 约束 3 创建一个表,有2个条件(1 有权限:2有表空间) Oracle给你提 ...
- 【转】Oracle回收站(recyclebin)
我们都比较熟悉windows中的回收站,文件删除后放到回收站里还可以再复原.Oracle回收站的原理完全一样,只是实现的细节方面有些差异.另外回收站中只能回收表和相关的对象包括索引.约束.触发器.嵌套 ...
- ORACLE回收站机制介绍
回收站概念 从ORACLE 10g开始,引入了一个叫回收站(Recycle Bin)的概念.它的全称叫Tablespace Recycle Bin.回收站实际是一个逻辑容器(逻辑区域),原理有点类似于 ...
- Oracle回收站使用全攻略
摘要:回收站(Recycle Bin)从原理上来说就是一个数据字典表,放置用户删除(drop)掉的数据库对象信息.用户进行删除操作的对象并没有被数据库删除,仍然会占用空间.除非是由于用户手工进行Pur ...
- Oracle回收站 使用
查询回收站 SELECT * FROM RECYCLEBIN; SELECT * FROM USER_RECYCLEBIN; --USER_RECYCLEBING与RECYCLEBIN是同义词,字段完 ...
- Oracle回收站
回收站是删除对象使用的存储空间.可以使用实例参数recyclebin禁用回收站,默认是on,可以为某个会话或系统设置为off或on.所有模式都有一个回收站. 当表空间不足时可以自动重用回收站对象占用的 ...
- Oracle回收站的清理方法
http://blog.itpub.net/18841027/viewspace-1057765/
随机推荐
- PHP共享内存
如何使用 PHP shmop 创建和操作共享内存段,使用它们存储可供其他应用程序使用的数据. 1. 创建内存段 共享内存函数类似于文件操作函数,但无需处理一个流,您将处理一个共享内存访问 ID.第一个 ...
- 然而,该来的还是来了(Diary)
2017-05-07 LG月赛成功炸掉...发现自己真的好多东西不会啊.对某些知识仅仅有最基础的一点理解啊!连线段树都理解不了怎么办?归并排序(including分治+贪心)全部炸掉啊.感觉自 ...
- [Ynoi2015]盼君勿忘
题目大意: 给定一个序列,每次查询一个区间\([l,r]\)中所有子序列分别去重后的和\(\bmod p\)(每次询问模数不同). 解题思路: 在太阳西斜的这个世界里,置身天上之森.等这场战争结束之后 ...
- [luogu 4886] 快递员
传送门 Solution 虽然不是点分治但用类似点分治的方法不断接近正确结果 Code // luogu-judger-enable-o2 #include <cstdio> #inclu ...
- 使用VirtualBox实现端口转发,以SSH与Django为例
先来认识几个概念 (1)IP地址:又称为互联网协议地址,是计算机的物理地址,相当于计算机的编号,是32位的二进制数,通常被分割成4个8位的二进制数: (2)端口:指设备与外界通讯的接口,一台计算机的端 ...
- 1、dubbo的概念
Dubbo是什么? Dubbo是阿里巴巴SOA服务化治理方案的核心框架,每天为2,000+个服务提供3,000,000,000+次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点. Dubbo[]是 ...
- (29)Spring boot 文件上传(多文件上传)【从零开始学Spring Boot】
文件上传主要分以下几个步骤: (1)新建maven java project: (2)在pom.xml加入相应依赖: (3)新建一个表单页面(这里使用thymleaf); (4)编写controlle ...
- 日志输出最不重要的就是控制台输出,控制台输出就是system.out而已
1.日志输出最不重要的就是控制台输出,控制台输出就是system.out而已 2.所以日志输出时候会存在一个Bug就是:stdout要配置在日志输出的最前面,因为stdout控制台输出,最不重要,如果 ...
- 歌乐电子一道非常easy的笔试题目居然搞错了!!!
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMjI0NzQ2Mg==/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...
- SQL SERVER读书笔记:阻塞与死锁
阻塞是事务隔离带来的副作用,而并不是SQL SERVER的错. 死锁则是互相争用资源而引发.由于死锁会选择牺牲者,所以死锁的危害没有阻塞大.但有时为了解决死锁,会采取对资源加锁,导致阻塞的方式来避免.