热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

EXP导出时DML操作对其导出数据是否有影响

随着数据库版本的升级及业务测试的增加,数据库或者数据迁移也成了数据库管理者们经常的工作之一。那么对于要求严格的数据,针对

随着数据库版本的升级及业务测试的增加,数据库或者数据迁移也成了数据库管理者们经常的工作之一。那么对于要求严格的数据,针对

一、概述

随着数据库版本的升级及业务测试的增加,数据库或者数据迁移也成了数据库管理者们经常的工作之一。那么对于要求严格的数据,针对大数据表,在你导出时如果有人做了操作,这个操作是否也会被导出呢?由于个人能力有限,想要深究逻辑备份的话,估计还需要一些时日,暂时只做了一个小实验测试,如大家有其他方法、更全面说明,欢迎拍砖。

二、操作过程

以下实验操作流程为每执行一次逻辑导出时都执行一次DML操作。操作语句如下(数据库版本10.2.0.5):

用户为firsoul,操作的表有age、big_table、test,下图为各表的初始数据


SQL> show user

USER is "FIRSOUL"

SQL> select * from tab;

SQL> select table_name,NUM_ROWS from user_tables;

TABLE_NAME NUM_ROWS

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

EMP 14

DEPT 4

TEST 1

AGE 1

BIG_TABLE 3000000

第一次操作:


exp firsoul/firsoul tables=BIG_TABLE COnSISTENT=Y file=exp_table.dmp log=exp_table.log
insert into age values(22,'mingli');

delete from big_table where id=7;

insert into test values(2,'shandong');

commit;

第二次操作:


exp firsoul/firsoul file=exp_user.dmp log=exp_user.log cOnsistent=y grants=y
insert into age values(24,'mengmeng');

delete from big_table where id=14;

insert into test values(3,'china');

commit;

第三次操作:


exp firsoul/firsoul tables=BIG_TABLE file=exp_table2.dmp log=exp_table2.log
insert into age values(24,'xiaochi');

delete from big_table where id=21;

insert into test values(4,'dezhou');

commit;

第四次操作:


exp firsoul/firsoul file=exp_user2.dmp log=exp_user2.log grants=y
insert into age values(25,'fengyin');

delete from big_table where id=28;

insert into test values(5,'jinan');

commit;

第五次操作:


expdp firsoul/firsoul directory=dir_dmp dumpfile=expdp_table.dmp tables=BIG_TABLE logfile=expdp_table.log
insert into age values(30,'shubin');

delete from big_table where id=35;

insert into test values(6,'shizhong');

commit;

第六次操作:


expdp firsoul/firsoul directory=dir_dmp dumpfile=expdp_user.dmp SCHEMAS=firsoul logfile=expdp_user.log
insert into age values(32,'liupan');

delete from big_table where id=42;

insert into test values(7,'tianqiao');

commit;

得出结果如下所示(“-”为少几行,“+”为多几行):

执行DML次数

age

big_table

test

备注

1

 

0

 

导出表(COnSISTENT=y)

2

+2

-2

+2

导出用户(COnSISTENT=y

3

 

-2

 

导出表(COnSISTENT=n)

4

+3

-3

+4

导出用户(COnSISTENT=n

5

 

-5

 

expdp 导出表

6

+6

-6

+6

expdp 导出用户

通过以上数据,我们可以看出

1、exp导出,参数COnSISTENT=y,单独导出表big_table,数据无变化,导出用户时,数据有变化。

2、exp导出,参数COnSISTENT=n,单独导出表big_table,数据无变化,导出用户数据时,表age、big_table没变化,表test多一行,exp导出按照表的首字母排序,在导出时,,我们执行DML语句(第四次操作)时,age已导出,big_table正在导出,而test还为等待导出。由此看出,exp导出,当表在执行导出时再做DML操作对导出数据无影响。

3、expdp导出时,数据都有变化。expdp导出的表是按照数据从大到小排序

三、总结

这个测试其实很无聊的,而且还有点绕,总结呢,就一点,exp任务开始,当该表已执行逻辑导出操作(执行中或已导出完成),做的任何DML操作对导出数据无影响;当导出任务还未涉及到该表时,所做DML操作影响该表导出数据。一句话,DML操作时间(先后)影响导出表数据。说来,还是对于数据库原理不太明白,希望可以认真看看吧,希望。以上只是个人昏昏欲睡状态下所得出结论,欢迎大家积极拍砖。水平有限,不足之处还望见谅。

Oracle EXP导出报错EXP-00091分析解决

探索Oracle之 EXP/IMP过程中的字符集问题

Oracle EXP imp备份、恢复表空间数据步骤

Oracle 创建自动执行的EXP任务

Oracle 11g 导出表报EXP-00011:table不存在

EXP/imp导出导入数据时报错ORA-12154 无法解析指定的连接标识符


推荐阅读
  • 如何在不同数据库中提取前N%的记录
    本文详细介绍了如何在SQL Server、Oracle和MySQL等不同数据库中提取前N%的记录。通过具体的示例和代码,帮助读者理解和掌握这些方法。 ... [详细]
  • Nacos 0.3 数据持久化详解与实践
    本文详细介绍了如何将 Nacos 0.3 的数据持久化到 MySQL 数据库,并提供了具体的步骤和注意事项。 ... [详细]
  • 解决SQL Server数据库sa登录名无法连接的问题
    在安装SQL Server数据库后,使用Windows身份验证成功,但使用SQL Server身份验证时遇到问题。本文将介绍如何通过设置sa登录名的密码、启用登录名状态以及开启TCP协议来解决这一问题。 ... [详细]
  • 在将Web服务器和MySQL服务器分离的情况下,是否需要在Web服务器上安装MySQL?如果安装了MySQL,如何解决PHP连接MySQL服务器时出现的连接失败问题? ... [详细]
  • SQL 连接详解与应用
    本文详细介绍了 SQL 连接的概念、分类及实际应用,包括内连接、外连接、自连接等,并提供了丰富的示例代码。 ... [详细]
  • 本文介绍了如何使用Flume从Linux文件系统收集日志并存储到HDFS,然后通过MapReduce清洗数据,使用Hive进行数据分析,并最终通过Sqoop将结果导出到MySQL数据库。 ... [详细]
  • 本文介绍了如何在 Spring 3.0.5 中使用 JdbcTemplate 插入数据并获取 MySQL 表中的自增主键。 ... [详细]
  • BIEE中的最终用户界面被称为Presentation Layer(展现层)。展现层呈现的内容与用户在Web报表开发界面中看到的一致,使用业务语言进行描述,隐藏了技术细节,如星型模型。本文将详细介绍展现层的设计要点及其与业务模型层的关系。 ... [详细]
  • Hadoop的文件操作位于包org.apache.hadoop.fs里面,能够进行新建、删除、修改等操作。比较重要的几个类:(1)Configurati ... [详细]
  • PHP 使用 Cookie 进行访问授权的方法
    本文介绍了如何使用 PHP 和 Cookie 实现访问授权,包括表单验证、数据库查询和会话管理等关键步骤。 ... [详细]
  • 本文详细介绍了Java代码分层的基本概念和常见分层模式,特别是MVC模式。同时探讨了不同项目需求下的分层策略,帮助读者更好地理解和应用Java分层思想。 ... [详细]
  • 操作系统如何通过进程控制块管理进程
    本文详细介绍了操作系统如何通过进程控制块(PCB)来管理和控制进程。PCB是操作系统感知进程存在的重要数据结构,包含了进程的标识符、状态、资源清单等关键信息。 ... [详细]
  • 基于iSCSI的SQL Server 2012群集测试(一)SQL群集安装
    一、测试需求介绍与准备公司计划服务器迁移过程计划同时上线SQLServer2012,引入SQLServer2012群集提高高可用性,需要对SQLServ ... [详细]
  • DAO(Data Access Object)模式是一种用于抽象和封装所有对数据库或其他持久化机制访问的方法,它通过提供一个统一的接口来隐藏底层数据访问的复杂性。 ... [详细]
  • 深入解析HTML5字符集属性:charset与defaultCharset
    本文将详细介绍HTML5中新增的字符集属性charset和defaultCharset,帮助开发者更好地理解和应用这些属性,以确保网页在不同环境下的正确显示。 ... [详细]
author-avatar
飞舞的猫2502890283
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有