flashback drop(2015-2-3学习日记)
知识面是由知识点组成的,你在研究某一个知识点的时候常常会遇到另一个知识点,然后你去研究那个知识点,又会带出更多的知识点,最终组成了知识面。
今天在看书的时候看到一个删除表的语句:
DROP TABLE AAA CASCADE CONSTRAINTS PURGE;
平时自己删除表,用的仅仅是DROP TABLE TABLENAME,后边从来没加过这几个参数,感觉好奇就找了几个资料研究了一番。
先说参数 CASCADE CONSTRAINTS
抄袭开始:
----------------------------------------------------------------------------
关于 cascade constraints
假设A为主表(既含有某一主键的表),B为从表(即引用了A的主键作为外键)。
则当删除A表时,如不特殊说明,则 drop table A 系统会出现错误警告的讯息而不会允许执行。
此时必须用,drop table A cascade constraints;
SQL> select CONSTRAINT_NAME,TABLE_NAME from dba_constraints where owner = 'SYS' and TABLE_NAME = 'B'
no rows selected
我们可以发现利用Drop table cascade constraints可以刪除从表的constraint來达成你drop table t的目的,原來属于B的foreign key constraint已经跟随着被删除掉了,但是,储存在table B中的资料不会被删除,也就是说Drop table cascade constraints 是不影响到存储于objec里的row data。
--------------------------------------------------------------------------------------------------------------------------
再说参数 PURGE
这个参数比较有意思,看了几篇文章才搞明白。
参考文章:
DROP TABLE ** CASCADE CONSTRAINTS PURGE
========================【拿来主义】========================
Oracle从10G开始支持DDL语句闪回,免去了之前误删除(DROP)表后恢复起来很困难的麻烦。9i版本恢复误删除的表很困难,具体怎么困难,我不知道。但是,10G后恢复就很简单了,那就是Oracle提供了flashback drop新特性。
使用flashback drop功能的注意事项(一下情况不能使用次功能):
1:表的存储表空间不能为system
2: 表被删除的时候不能带purge参数
3:存在空间压力的时候
4:表上面启用了细粒度审计
5:表启用了VPD
(题外话:这个4和5对我来说又是新的知识点,哎,抽时间再研究吧。)
开启回收站功能:
SQL> show parameter recyclebin;
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
recyclebin string on
实验测试flashback drop功能:
创建表AAA:
SQL> create table aaa (name varchar2(20));
Table created
向表AAA插入数据:
SQL> insert into aaa values ('1234');
1 row inserted
SQL> insert into aaa values ('1234');
1 row inserted
查询数据:
SQL> select * from aaa;
NAME
--------------------
1234
1234
查询user_recyclebin中有没有关于AAA的记录:
SQL> select * from user_recyclebin where original_name ='AAA';
OBJECT_NAME ORIGINAL_NAME OPERATION TYPE TS_NAME CREATETIME DROPTIME DROPSCN PARTITION_NAME CAN_UNDROP CAN_PURGE RELATED BASE_OBJECT PURGE_OBJECT SPACE
------------------------------ -------------------------------- --------- ------------------------- ------------------------------ ------------------- ------------------- ---------- -------------------------------- ---------- --------- ---------- ----------- ------------ ----------
(没有数据)
删除AAA:
SQL> drop table aaa;
Table dropped
SQL> select * from user_recyclebin where original_name ='AAA';
OBJECT_NAME ORIGINAL_NAME OPERATION TYPE TS_NAME CREATETIME DROPTIME DROPSCN PARTITION_NAME CAN_UNDROP CAN_PURGE RELATED BASE_OBJECT PURGE_OBJECT SPACE
------------------------------ -------------------------------- --------- ------------------------- ------------------------------ ------------------- ------------------- ---------- -------------------------------- ---------- --------- ---------- ----------- ------------ ----------
BIN$ljh1zkU8SUqaTs8kGHS6mg==$0 AAA DROP TABLE TS_FPZX_DAT 2015-02-03:16:50:10 2015-02-03:16:51:05 29344784 YES YES 94499 94499 94499 8
再次查询表(已经被删除)
SQL> select * from aaa;
select * from aaa
ORA-00942: 表或视图不存在
再次建立表AAA:
SQL> create table aaa (name varchar2(20));
Table created
插入数据:
SQL> insert into aaa values ('abcd');
1 row inserted
SQL> insert into aaa values ('abcd');
1 row inserted
不查询了,直接删除吧:
SQL> drop table aaa;
Table dropped
再次查询变化:
SQL> select OBJECT_NAME,ORIGINAL_NAME,OPERATION,TYPE,CREATETIME,DROPTIME from user_recyclebin where original_name ='AAA';
OBJECT_NAME ORIGINAL_NAME OPERATION TYPE CREATETIME DROPTIME
------------------------------ ------------- --------- --------- ----------------- -----------------
BIN$ljh1zkU8SUqaTs8kGHS6mg==$0 AAA DROP TABLE 2015-02-03:16:50:10 2015-02-03:16:51:05
BIN$pk7Yt+SeRhOpF7UvsMuTrg==$0 AAA DROP TABLE 2015-02-03:16:52:04 2015-02-03:16:52:20
此时user_recyclebin中有两条关于AAA的记录,我们此时要是用语句恢复数据的话,恢复的是第二次删除的表中的数据:
SQL> flashback table aaa to before drop;
Done
查询数据:
SQL> select * from aaa;
NAME
--------------------
abcd
abcd
此时user_recyclebin 表中只剩一条数据了,这个数据中的表AAA,保存的就是第一张表里边的‘1234’的数据。我们来还原它的话需要另命名,因为已经恢复了AAA:
SQL> select OBJECT_NAME,ORIGINAL_NAME,OPERATION,TYPE,CREATETIME,DROPTIME from user_recyclebin where original_name ='AAA';
OBJECT_NAME ORIGINAL_NAME OPERATION TYPE CREATETIME DROPTIME
------------------------------ ------------- --------- --------- ----------------- -----------------
BIN$ljh1zkU8SUqaTs8kGHS6mg==$0 AAA DROP TABLE 2015-02-03:16:50:10 2015-02-03:16:51:05
闪回第一张AAA,加上rename关键字:
SQL> flashback table aaa to before drop rename to AAA2;
Done
查询数据:
SQL> select * from aaa2;
NAME
--------------------
1234
1234
另:
>>>>>>PURGE TABLESPACE USER SCOTT; //清除特定表空间特定用户的回收站
>>>>>>PURGE DBA_RECYCLEBIN; //清除任何表空间中的所有对象
flashback drop(2015-2-3学习日记)的更多相关文章
- Linux学习日记-使用EF6 Code First(四)
一.在linux上使用EF 开发环境 VS2013+mono 3.10.0 +EF 6.1.0 先检测一下EF是不是6的 如果不是 请参阅 Linux学习日记-EF6的安装升级(三) 由于我的数据库 ...
- 2015 WEB前端学习路线图
2015 WEB前端学习路线图,欢迎小伙伴补充 @落雨
- android学习日记05--Activity间的跳转Intent实现
Activity间的跳转 Android中的Activity就是Android应用与用户的接口,所以了解Activity间的跳转还是必要的.在 Android 中,不同的 Activity 实例可能运 ...
- android学习日记03--常用控件Dialog
常用控件 9.Dialog 我们经常会需要在Android界面上弹出一些对话框,比如询问用户或者让用户选择.这些功能我们叫它Android Dialog对话框 对话框,要创建对话框之前首先要创建Bui ...
- android学习日记03--常用控件checkbox/radiobutton
常用控件3.checkbox 复选框,确定是否勾选,点击一下勾选,点击第二下取消,当有一系列备选项时适合用checkbox控件,方便用户提交数据. 贴上例子Activity的java代码 packag ...
- android学习日记03--常用控件button/imagebutton
常用控件 控件是对数据和方法的封装.控件可以有自己的属性和方法.属性是控件数据的简单访问者.方法则是控件的一些简单而可见的功能.所有控件都是继承View类 介绍android原生提供几种常用的控件bu ...
- Zend Framework学习日记(2)--HelloWorld篇(转)
Zend Framework学习日记(2)--HelloWorld篇 这一篇主要演示如何用zf命令行工具建立一个基于Zend Framework框架的工程,也是我初学Zend Framework的小练 ...
- Zend Framework学习日记(1)--环境搭建篇(转)
Zend Framework学习日记(1)--环境搭建篇 (1)开发工具 Zend Framework框架:http://framework.zend.com/download/latest 包含2个 ...
- Python 学习日记(第三周)
知识回顾 在上一周的学习里,我学习了一些学习Python的基础知识下面先简短的回顾一些: 1Python的版本和和安装 Python的版本主要有2.x和3.x两个版本这两个版本在语法等方面有一定的区别 ...
随机推荐
- 包管理器Bower使用手册之一
包管理器Bower使用手册之一 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs 一.Bower介绍 Bower是一个适合Web应用的包管理器,它擅长前端的 ...
- node开子线程模块--tagg2
tagg2包同样具有tagg包的多线程功能,采用新的node-gyp命令进行编译,同时它跨平台支持,mac,linux,windows下都可以使用,对开发人员的api也更加友好.安装方法很简单,直接n ...
- Poco库之XML操作
平台ubuntu14.04LTS Poco版本:Poco1.6.1 #include <Poco/DOM/Text.h>#include <Poco/DOM/Element. ...
- 我用C#调用C编译的dll中有这样一个函数,函数大概的功能就是把数据保存到buf缓冲区中:
我用C#调用C编译的dll中有这样一个函数,函数大概的功能就是把数据保存到buf缓冲区中: C/C++ code ? 1 int retrieve(int scanno,void* buf); 在 ...
- MySQL下Limit使用及性能分析
对于一直用Oracle的我,今天可是非常诧异,MySQL中同一个函数在不同数量级上的性能居然差距如此之大. 先看表ibmng(id,title,info) 唯一 id key 索引title 先看 ...
- NotePad++更改背景颜色
白色的编辑框看得眼睛不舒服,怎么样更改NotePad++的背景颜色使眼睛更舒服些? 1.设置--语言格式设置 2.设置背景色 “背景色”一栏,选择背景色颜色 “使用全局背景色”一栏要打上√,否则无 ...
- IOS公司开发者账号申请详细教程--1 备用
谈到苹果开发者账号,我们需要区分一下个人账号.公司账号和企业账号这三种,还有一种是教育账号,这个就不多说了. 个人账号:个人申请用于开发苹果app所使用的账号,仅限于个人使用,申请比较容易,$99. ...
- Aircrack-ng官方文档翻译[中英对照]---Aireplay-ng
Aircrack-ng官方文档翻译---Aireplay-ng[90%] Description[简介] Aireplay-ng is used to inject frames. Aireplay- ...
- java 堆与栈的区别
1. 堆与栈的区别? 1-1. 数据存放位置: 数据都存放于RAM (Random Access Memory). 1-2. 存放数据的类型:stack栈中保存方法中的基本数据类型(int, do ...
- VC下载文件 + 显示进度条
在codeproject里找了许久,发现这样一个VC下载文件并显示进度条的源码,于是添加了些中文注释: 1.下载线程函数: UINT DownloadFile(LPVOID pParam) { CWn ...