flashback_scn导出
1.应用场景
2.oracle实现该技术的原理理论,及限制
3.实操及与scn时间相关的函数查询
一、flashback_scn导出
1) OGG同步,对表的数据进行同步,第一次可以完全导出,中途如果由于某些原因导致数据中断时间过长,可以根据OGG日志得到目标端最后应用同步成功的SCN,选择这个SCN前一点点在源端导出即可无需全部导出:
2)使用expdp进行数据迁移,在子表导入,报ORA-39083、ORA-02298,父表中不存在子表相关的记录,因此外建约束无法创建
解决方法:停应用重新导出导入、指定flashback_scn导出导入、使用如下SQL删除子表中不符合的行,进行删除,手工创建约束。
ORA-39083 And ORA-2298 Encountered During DataPump Import (Doc ID 462645.1)	ORA-39083: 
select <FK_column_name> from <child_table>
minus
select <PK_column_name> from <parent_table>;
如下链接,说明在导出的过程中,如果对表进行dml操作且成功,导出程序读取数据时将按照实际情况进行导出,因此数据与最初执行导出存在不一致。
Expdp Message "FLASHBACK automatically enabled" Does Not Guarantee Export Consistency (Doc ID 377218.1)
二、原理理论
通过Undo构建历史时间节点的blocks,达到在某个时间节点数据一致性的现象。
undo保留时间无法保留过长的数据,Undo空间不足信息被覆盖。
三、实操
数据库当前SCN查询
SQL> select dbms_flashback.get_system_change_number scn,current_scn from v$database;
       SCN CURRENT_SCN
---------- -----------
   1276822     1276822
SQL>select to_char(scn_to_timestamp(current_scn),'yyyy-mm-dd hh24:mi:ss') as "date" from v$database
date
-------------------
2019-04-21 19:00:28
select to_char(scn_to_timestamp(1276822),'yyyy-mm-dd hh24:mi:ss') from dual;
TO_CHAR(SCN_TO_TIME
-------------------
2019-04-21 19:04:01
SQL> create table a(id int);
SQL> insert into a values(1);
SQL> commit;
SQL> select dbms_flashback.get_system_change_number scn,current_scn from v$database;
       SCN CURRENT_SCN
---------- -----------
   1276903     1276903
SQL> insert into a values(2);
SQL> commit;
Starting "SYS"."SYS_EXPORT_TABLE_01":  '/******** AS SYSDBA' directory=dump dumpfile=test1.dmp tables=a 
Estimate in progress using BLOCKS method...
Processing object type TABLE_EXPORT/TABLE/TABLE_DATA
Total estimation using BLOCKS method: 0 KB
ORA-39166: Object A was not found.
ORA-31655: no data or metadata objects selected for job
DataPump Export (EXPDP) Fails With Error ORA-39165: Schema SYS Was Not Found (Doc ID 553402.1)	
SQL> create table system.a as select * from a;
SQL> select dbms_flashback.get_system_change_number scn,current_scn from v$database; 
       SCN CURRENT_SCN
---------- -----------
   1303531     1303531
 delete system.a where id=2;
 commit;
SQL>  select dbms_flashback.get_system_change_number scn,current_scn from v$database; 
       SCN CURRENT_SCN
---------- -----------
   1303545     1303545
[oracle@enmo ~]$ expdp system/oracle directory=dump dumpfile=test1.dmp tables=a
. . exported "SYSTEM"."A"                                4.921 KB       1 rows
[oracle@enmo ~]$ expdp system/oracle directory=dump dumpfile=test3.dmp tables=a FLASHBACK_SCN=1303531
. . exported "SYSTEM"."A"                                4.929 KB       2 rows
flashback_scn导出的更多相关文章
- 使用数据泵导入(impdp)和导出(expdp)
		
数据泵技术是Oracle Database 10g 中的新技术,它比原来导入/导出(imp,exp)技术快15-45倍.速度的提高源于使用了并行技术来读写导出转储文件. expdp使用 使用EXPDP ...
 - EXP的flashback_scn和flashback_time
		
数据库设置 a. 设置UNDO_RETENTION的初始值(在短时间内)代表你想要查过去多远的时间. b. 设置初始化参数UNDO_MANAGEMENT=AUTO. c. 建立一个还原点空间,要有足够 ...
 - PLSQL_数据泵导入导出数据Impdp/ Expdp(概念)
		
2014-08-31 Created By BaoXinjian
 - Oracle基础 数据泵导出/导入Expdp/impdp(转)
		
一.EXPDP和IMPDP使用说明 Oracle Database 10g引入了最新的数据泵(Data Dump)技术,数据泵导出导入(EXPDP和IMPDP)的作用 1)实现逻辑备份和逻辑恢复. 2 ...
 - Oracle基础 exp/imp   数据泵导入/导出  命令
		
一.导出方式: 使用exp/imp方式导出数据分为四种方式: 1.表方式导出:一个或多个指定的表,包括表的定义.表数据.表的所有者授权.表索引.表约束,以及创建在该表上的触发器.也可以只导出结构,不导 ...
 - Oracle导入导出之dmp
		
Oracle导入导出有两种方式,分别是imp/exp与impdp/expdp. 1.imp/exp exp scott/tiger file=d:\test.dmp log=d:\test.log o ...
 - (转载)Oracle10g 数据泵导出命令 expdp 使用总结(二)
		
原文链接:http://hi.baidu.com/edeed/item/2c454cff5c559f773d198b94 Oracle10g 数据泵导出命令 expdp 使用总结(一) 1.1.2 e ...
 - imp、exp命令导出优化
		
本文对Oracle数据的导入导出 imp ,exp 两个命令进行了介绍, 并对其对应的參数进行了说明,然后通过一些演示样例进行演练,加深理解.文章最后对运用这两个命令可能出现的问题(如权限不够,不同o ...
 - exp/expdp 与 imp/impdp命令导入导出数据库详解
		
一.exp命令导出数据库 如何使exp的帮助以不同的字符集显示:set nls_lang=simplified chinese_china.zhs16gbk,通过设置环境变量,可以让exp的帮助以中文 ...
 
随机推荐
- 【nowcoder】 4th T1 动态点分治
			
题目链接:https://www.nowcoder.com/acm/contest/175/A 题目名字吓死人 std: 我 太可啪了 一道简单的模拟题.虽然我把题意想错了. 按照题意模拟输出和继承. ...
 - mysql 联合表(federated)及视图
			
1)验证环境 源库:192.168.8.75 centos 7.5 mysql8.3 目标库:192.168.8.68 redhat 6.8 mysql5.7 2)登录源库并创建源表 $ mysql ...
 - 转载:dos批处理中路径获取
			
在DOS的批处理中,有时候需要知道当前的路径. 在DOS中,有两个环境变量可以跟当前路径有关,一个是%cd%, 一个是%~dp0. 这两个变量的用法和代表的内容是不同的. 1. %cd% ...
 - 简单的epub制作
			
最近在无聊看轻小说的时候,找到了一套叫<白银龙王的摇篮>的书. 台版一共出了6卷,并且wenku8都已经录入了,但是轻国的epub录入只有2卷. 我寻思着做epub也不是什么难事,就稍微百 ...
 - javascript 十进制转换为二进制
			
1.十进制转换为二进制 var toBin = (n) => { if(n == 0) return '0'; var res = ''; while(n != 0) { res = n % 2 ...
 - sass中文注释的解决方法和一些简单用法
			
最近用sass来编写项目中的css,发现不能添加中文注释,报错如下 于是查阅了一下发现需要在scss文件顶部加上@charset "utf-8"即可解决. 在此顺便记录一些sass ...
 - PHP 轻量级 REST框架
			
GITHUB:https://github.com/jacwright/RestServer 简介: 一个PHP REST服务器,用于提供非常轻量级的REST API.很容易上手.独立于其他库和框架. ...
 - cocoapods 换源
			
1. 用以下步骤换源: pod repo remove master pod repo add master https://code.aliyun.com/Magi/CocoaPods.git po ...
 - 【webpack学习笔记】a04-建立开发环境
			
开发环境就是在开发过程中为了方便配置的环境,生产环境就是开发完成即将上线的情况. 好了,说了句废话,切入正题. 在开发时,打包后的文件压缩成一团,报错调试的时候傻眼了有木有?每次做出修改需要到浏览器查 ...
 - [模板]quicksort快速查找、排列算法
			
1.快速排序 //快速排序 void quick_sort(int s[], int l, int r) { if (l < r) { //Swap(s[l], s[(l + r) / 2]); ...