导航:首页 > 废水知识 > 用表闪回

用表闪回

发布时间:2024-07-30 19:20:08

❶ Oracle 使用Flashback方式数据恢复,但是表中有CLOB字段,提示:快照旧了

  1. 使用闪回数据库,闪回后以read only模式打开,导出该表,然后重启数据库,做recover,打开,再导入;

  2. 使用基于时间点的恢复,和1差不多;

  3. 如果是11g版本以上,考虑以后用闪回数据归档。

❷ 求教Oracle11g中的闪回技术

1、Flashback Database(利用闪回日志恢复)

Oracle Flashback Database特性允许通过SQL语句Flashback Database语句,让数据库前滚到当前的前一个时间点或者SCN,而不需要做时间点的恢复。闪回数据库可以迅速将数据库回到误操作或人为错误的前一个时间点,如Word中的"撤消"操作,可以不利用备份就快速的实现基于时间点的恢复。Oracle通过创建新的Flashback Logs(闪回日志),记录数据库的闪回操作。如果希望能闪回数据库,需要设置如下参数:DB_RECOVER_FILE_DEST日志的存放位置,DB_RECOVER_FILE_DEST_SIZE恢复区的大小。在创建数据库的时候,Oracle将自动创建恢复区,但默认是关闭的,需要执行alter database flashback on命令。

例:执行Flashback Database命令格式。

SQL>flashback database to time to_timestamp(xxx);

SQL>flashback database to scn xxx

2、Flashback Table(利用UNDO保留信息恢复)

Oracle Flashback Table特性允许利用Flashback Table语句,确保闪回到表的前一个时间点。与Oracle 9i中的Flashback Query相似,利用回滚段信息来恢复一个或一些表到以前的一个时间点(一个快照)。要注意的是,Flashback Table不等于Flashback Query,Flashback Query仅仅是查询以前的一个快照点而已,并不改变当前表的状态,而Flashback Table将改变当前表及附属对象一起回到以前的时间点。

语法:

flashback table tablename to timestamp xxx或

flashback table tablename to scn xxx

注意:如果需要闪回一个表,需要以下条件:

需要有flashback any table的系统权限或者是该表的flashback对象权限;

需要有该表的select,insert,delete,alter权限;

必须保证该表row movement。

例:执行将test表闪回到2011年5月7日下午3点。

SQL>flashback table test to timestamp to_timestamp(’2011-05-07 15:00:00’,’yyyy-mm-dd hh24:mi:ss’);

3、Flashback Drop(利用回收站功能恢复)

注:由于目前的环境为了实现OGG的DDL同步,关闭了回收站功能,故这个功能不可用。

4、Flash Version Query(利用UNDO保留信息恢复)

Oracle Flashback Version Query特性,利用保存的回滚信息,可以看到特定的表在时间段内的任何修改,如电影的回放一样,可以了解表在该期间的任何变化。Flashback version query一样依赖于AUM,提供了一个查看行改变的功能,能找到所有已经提交了的行的记录,分析出过去时间都执行了什么操作。Flashback version query采用VERSIONS BETWEEN语句来进行查询,常用的方法:

·VERSIONS_SCN - 系统改变号

·VERSIONS_TIMESTAMP - 时间

例如:在test表中,时间1插入一条记录,时间2删除了这条记录,对于时间3执行select * from test当然查询不到这条记录,只能看到该表最后的提交记录。这时如果利用Flash Table或者是Flash Query,只能看到过去的某一时间点的一个快照,而利用Flashback Version Query,能够把时间1、时间2的操作给记录下来,并详细的查询出对表进行的任何操作。

基于SCN的闪回查询:

SQL> select count(*) from lm_mtrp_syn_channelinfo as of scn 708000000;

COUNT(*)

----------

21

基于时间段的闪回查询:

SQL>select versions_starttime,versions_endtime, versions_xid,versions_operation,id

from test versions

between timestamp minvalue and maxvalue

order by versions_starttime;

5,Flashback Transaction Query(利用UNDO保留信息恢复)

Oracle Flashback Transaction Query特性确保检查数据库的任何改变在一个事务级别,可以利用此功能进行诊断问题、性能分析和审计事务。它其实是Flashback Version Query查询的一个扩充,Flashback Version Query说明了可以审计一段时间内表的所有改变,但是也仅仅是能发现问题,对于错误的事务,没有好的处理办法。而Flashback Transaction Query提供了从FLASHBACK_TRANSACTION_QUERY视图中获得事务的历史以及Undo_sql(回滚事务对应的sql语句),也就是说审计一个事务到底做了什么,甚至可以回滚一个已经提交的事务。

例:Flashback Transaction Query的操作实例。

(1)在test表中删除记录,获得事务的标识XID,然后提交。

SQL>delete from test where id=2;

SQL>select xid from v$transaction;

XID

----------------

04001200AE010000

SQL>commit;

在测试中方便起见,在事务没有提交的时候,获得事务的XID为04001F0035000000。实际情况下,不可能去跟踪每个事务,想要获得已提交事务的XID,就必须通过上面的Flashback Version Query。

(2)进行Flashback Transaction Query

SQL>select * from FLASHBACK_TRANSACTION_QUERY

where xid=’04001F0035000000’;

UNDO_SQL

insert into "FLASHTEST"."TEST"("ID") values (’2’);

注意:这个删除语句对应的是1个Insert语句,如果想回滚这个事务,执行这个Insert语句即可。

可以看到,Flashback Transaction Query主要用于审计一个事务,并可以回滚一个已经提交的事务。如果确定出错的事务是最后一个事务,我们利用Flashback Table或者Flashback Query就可以解决问题。但是,如果执行了一个错误的事务之后,又执行了一系列正确的事务,那么上面的方法就无能为力,利用Flashback Transaction Query可以查看或回滚这个错误的事务。

另:ORACLE 11G还多了一个闪回数据归档的功能,即可将UNDO的信息进行归档,这个功能对于一些比较重要的表,

❸ oracle数据库中闪回和回收站不是一个意思吗

这里说点自己的理解抄,不写那些名词解释了。
闪回功能和回收站并不一样。
举例来说,闪回一般操作就是短时间内的恢复(DML操作,个人感觉类似于win的ctrl+z(不过没有win的好用))。比如说你刚刚删除了数据,那么利用闪回功能可以回到删除之前。但是如果表的交易量很大,或者时间过长,那么就不能回到你需要的时间(比如你想回到一天前,那闪回是基本不可能实现的)
回收站则不同,它主要是删除段的放置空间。和windows的回收站一个意思(什么见过回收站能还原一段在word中删除的内容的),就是将删除的段放置在这里。oracle中drop的段(主要是表),如果不加purge(加了就是彻底删除),那么就会放置在回收站中,就好像我们在win系统中的删除,如果直接删除一个文件,那么在回收站中,如果是shift+del那么就是彻底删除,不可恢复。
其实回收站的表是可以看到的,就是那些一堆乱码(BIN$开头的字符串)表名的表。可以用show recyclebin查到,也可以zairecyclebin的视图中看到。

❹ oracle涓鍏充簬flashback闂鍥炵殑浠嬬粛

1銆佸繀椤昏惧畾undo淇濈暀鏃堕棿瓒冲熷ぇ浠ヨ兘澶熼噸鏋勯渶瑕侀棯鍥炵殑鏁版嵁
ALTER SYSTEM SET UNDO_RETENTION=SECONDS; seconds鍊兼槸undo鏁版嵁淇濇寔鐨勭掓暟銆
Flashback view鏄鐢眜ndo retention interval鏉ラ檺鍒剁殑銆
2銆佸寘DBMS_FLASHBACK鎻愪緵浜嗛渶姹傛帴鍙
call dbms_flashback.enable_at_time锛堚2010-10-19:11:00:00鈥欙級锛
call dbms_flashback.disable锛堬級锛
-------------------------------------
enable_at_time锛氫細璇濈骇鐨別nable flashback锛屾槧鍍忔椂闂磋璁惧畾涓烘渶鎺ヨ繎鎸囧畾鏃堕棿鎴崇殑scn
enable_at_system_change_number:灏嗘暟鎹搴撻棯鍥炲埌鎸囧畾鐨剆cn鍙枫
get_system_change_number:杩斿洖褰撳墠鐨剆cn銆
disable锛氳繖涓瀛樺偍杩囩▼鍏佽告垜浠鍦ㄦ暣涓浼氳瘽鍐呭仠姝flashback骞跺皢浣犲甫鍥炲綋鍓嶆椂闂寸殑鏁版嵁鐘舵併
----------
dbms_flashback.enable瀛樺偍杩囩▼涓嶅彲浠ュ湪鏈夋椿鍔ㄤ簨鍔$殑鏃跺欐墽琛岋紝骞朵笖锛岃繖涓鍖呬笉鑳界敤sys韬浠芥墽琛屻
鍦ㄤ娇鐢―BMS_FLASHBACK.ENABLE_AT_TIME鍓嶏紝浣犲繀椤昏惧畾浣犵殑NLS_DATE_FORMAT鐨勭簿纭绋嬪害锛孫racle榛樿ょ殑鏄绮剧‘鍒板ぉ
3銆乼imestamp 涓巗cn锛堢郴缁熸敼鍙樺彿锛 鐨勫瑰簲鍏崇郴
浜嬪疄涓婏紝Oracle鍦ㄥ唴閮ㄩ兘鏄浣跨敤scn锛屽嵆浣夸綘鎸囧畾鐨勬槸as of timestamp锛宱racle涔熶細灏嗗叾杞鎹㈡垚scn锛岀郴缁熸椂闂存爣璁颁笌scn涔嬮棿瀛樺湪涓寮犺〃锛屽嵆SYS涓嬬殑SMON_SCN_TIME琛ㄣ
姣忛殧5鍒嗛挓锛岀郴缁熶骇鐢熶竴娆$郴缁熸椂闂存爣璁颁笌scn鐨勫尮閰嶅苟瀛樺叆sys.smon_scn_time琛锛岃ヨ〃涓璁板綍浜嗘渶杩1440涓绯荤粺鏃堕棿鏍囪颁笌scn鐨勫尮閰嶈板綍锛岀敱浜庤ヨ〃鍙缁存姢浜嗘渶杩戠殑1440鏉¤板綍锛屽洜姝ゅ傛灉浣跨敤as of timestamp鐨勬柟寮忓垯鍙鑳絝lashback鏈杩5澶╁唴鐨勬暟鎹锛堝亣璁剧郴缁熸槸鍦ㄦ寔缁涓嶆柇杩愯屽苟鏃犱腑鏂鎴栧叧鏈洪噸鍚涔嬬被鎿嶄綔鐨勮瘽锛夈係YS.SMON_SCN_TIME鏈澶氭嫢鏈1440鏉¤板綍銆傝繖涓鏈澶ц板綍鏁版槸杩欐牱璁$畻鍑烘潵鐨勶紝ORACLE骞冲潎姣5鍒嗛挓鍚屾ヤ竴娆¤ヨ〃鏁版嵁锛屾渶澶т繚瀛樻渶杩5澶╃殑璁板綍锛屽洜姝ゅ氨鐩稿綋浜12锛堟瘡灏忔椂鏇存柊娆℃暟锛*24*5=1440銆
鍙浠ョ敤sql楠岃瘉涓涓嬶細
Sql浠g爜
select scn,to_char锛坱ime_dp,'yyyy-mm-dd hh24:mi:ss'锛 from sys.smon_scn_time;
10g涓鎻愪緵浜嗕袱涓鍑芥暟scn_to_timestamp锛堬級 鍜宼imestamp_to_scn锛堬級 鐢ㄦ潵鎵ц屾椂闂存埑鍜孲CN鐨勮浆鎹銆
涓嬮潰浣跨敤闂鍥炶繘琛屾紨绀轰竴涓嬶細
1銆佺櫥闄嗗埌鏁版嵁搴撱
Sql浠g爜
C:sqlplus tivan/tivan
SQL*Plus: Release 10.2.0.1.0 - Proction on 鏄熸湡浜 10鏈 19 22:24:03 2010
Copyright 锛坈锛 1982, 2005, Oracle. All rights reserved.
杩炴帴鍒帮細
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Proction
With the Partitioning, OLAP and Data Mining options
2銆佹煡鐪嬭〃鐨勮板綍銆
Sql浠g爜
SQL select count锛*锛 from t1
2 ;
COUNT锛*锛
----------
8302
3銆佸垹闄ゆ墍鏈夌殑璁板綍鎻愪氦銆
Sql浠g爜
SQL delete from t1
2 ;
宸插垹闄8302琛屻
SQL commit;
鎻愪氦瀹屾垚銆
4銆佽幏寰楀綋鍓峉CN
濡傛灉鑳藉熺‘鍒囩煡閬撳垹闄や箣鍓峉CN鏈濂斤紝濡傛灉涓嶇煡閬擄紝鍙浠ヨ繘琛岄棯鍥炴煡璇㈠皾璇曘
Sql浠g爜
SQL select dbms_flashback.get_system_change_number from al;
GET_SYSTEM_CHANGE_NUMBER
------------------------
1482649
SQL select count锛*锛 from t1 as of scn 1482600;
COUNT锛*锛
----------
8302
SCN=1482600鏃讹紝t1琛ㄤ腑鐨勬墍鏈夎板綍閮借繕鍦ㄣ
5銆佸埄鐢ㄩ棯鍥炴仮澶嶆暟鎹銆
鏌ョ湅楠岃瘉涓涓嬶細
Sql浠g爜
SQL insert into t1 select * from t1 as of scn 1482600;
宸插垱寤8302琛屻
SQL commit;
鎻愪氦瀹屾垚銆
缁撴灉OK
鎴栬呰繕鍙浠ュ備笅鎿嶄綔
Sql浠g爜
SQLflashback table t1 to scn 1482600;
SQL commit;
Commit complete.
--瀵逛簬drop table t1 鐨勬搷浣渇lashback
SQL drop table t1;
SQLCOMMIT;
SQL flashback table t1to before drop;
SQLcommit;
瀵逛簬鎬庝箞鍙栫殑SCN鍙浠ヤ娇鐢╰imestamp_to_scn锛堬級 鍑芥暟锛屽傦細
Sql浠g爜
select timestamp_to_scn锛坱o_timestamp锛񟭊-10-19 21:00:00','YYYY-MM-DD HH:MI:SS'锛夛級 from al;

❺ 高手指点oracle闪回表有哪些限制

用网络能搜大把出来吧。。。。

使用的限制和注意事项:
1. 使用闪回表语句恢复表到出现人为或应用错误事件之前的状态。

2. 可以闪回到过去多长时间取决于系统中undo数据量的大小。

3. 并且oracle数据库无法恢复通过DDL语句修改了结构的表。

4.oracle强烈建议设置UNDO_MANAGEMENT为AUTO(自动管理回滚数据)。另外,设置UNDO_RETENTION (回滚数据的保留时间)为一个合适的时间间隔。

5.你不能回滚flash back语句,然而你可以使用另外一个flash back语句并且指定一个当前时间之前的时间点。在声明一个flash back语句之前先记录下当前的SCN号。

另外如果要使用闪回表

1. 我们需要有在指定表上有flashback的权限或者FLASHBACK ANYTABLE权限才能闪回一个表到之前的时间点;

2.必须有对表的SELECT, INSERT, DELETE, andALTER object privileges一系列权限;

3.除非是使用TO BEFORE DROP,对于分区表的闪回都应该开启Row movement (alter table test_move enable row movement;)
一般用于分区表,某一行更新时,如果更新的是分区列,并且更新后的列值不属于原来的这个分区,如果开启了这个选项,就会把这行从这个分区中delete 掉,并加到更新后所属的分区。相当于一个隐式的delete+insert,但是不会触发insert/delete触发器。如果没有开启这个选项,就会在更新时报错。

4.恢复一个表到一个还原点,必须拥有SELECT ANY DICTIONARY orFLASHBACKANY TABLE system privilege or theSELECT_CATALOG_ROLE role。

阅读全文

与用表闪回相关的资料

热点内容
超滤膜膜丝怎样防止爬胶 浏览:364
污水处理漂白粉加多少 浏览:467
净水机有水碱是什么原因 浏览:233
东莞污水厂废气治理多少钱 浏览:708
污水泡沫对人体有什么危害 浏览:250
日本排入废水最新消息 浏览:238
社区紧急联系抢修污水外流怎么办 浏览:239
不锈钢蜂蜜化晶过滤器 浏览:278
香港蒸馏水广告古天乐 浏览:489
三聚异氰胺树脂 浏览:396
超滤膜正冲洗 浏览:914
qq音乐播放器音质会提升吗 浏览:761
河北污水排水管多少钱 浏览:37
污水水池要做什么实验 浏览:487
小米净水废水怎么排 浏览:430
什么水不会起水垢 浏览:577
纯净水比普通水有什么好处 浏览:766
温度降低半透膜 浏览:762
我国园区污水处理厂 浏览:753
聚三氟氯乙烯树脂f2314 浏览:803