• oracle 数据导入导出


    一、oracle中copy from的用法

     

    1.语法及使用说明  

    1.1 语法  

    下面我们来看一下SQL*Copy Command的语法及使用说明。  

    在解释SQL*Plus Copy Command的语法之前,我们必须要明确SQL*Plus Copy Command不是一个方法或是函数,也不是一个SQL语句,它是一个命令(command),当然这个命令必须在SQL*Plus里运行。  

      

    SQL*Plus Copy Command的语法:  

    COPY {FROM database | TO database | FROM database TO database} {APPEND|CREATE|INSERT|REPLACE} destination_table [(column, column, column, ...)]  

    USING query  

      

    我们分部分来解释一下:  

      

    COPY – 这个不太需要解释,主命令,声明要执行COPY操作  

      

    From Database – 源数据库  

    To Database – 目标数据库  

    此处注意花括号中有三种可选的写法(以”|”隔开),如果源数据表和目标数据表在同一个Schema中,则可以只写From Database,也可以只写To Database,当然还可以是第三种写法,把From Database和To Database写全。但如果源数据表和目标数据表不在同一个Schema中,则必须用第三种写法,即把From Database和To Database都写全  

    From Database和To Database的格式是一样的:USERID/PASSWORD@SID,这个大家都应该很熟悉了。  

      

    {APPEND|CREATE|INSERT|REPLACE} – 声明操作数据的方式,下面分别解释一下:  

    Append – 向已有的目标表中追加记录,如果目标表不存在,自动创建,这种情况下和Create等效。  

    Create – 创建目标表并且向其中追加记录,如果目标表已经存在,则会返回错误。  

    Insert – 向已有的目标表中插入记录,与Append不同的是,如果目标表不存在,不自动创建而是返回错误。  

    Replace – 用查询出来的数据覆盖已有的目标表中的数据,如果目标表不存在,自动创建。  

      

    destination_table – 目标表的名字  

    [(column, column, column, ...)] – 可以指定目标表中列的名字,如果不指定,则自动使用Query中的列名。  

    USING query – 查询语句,交流的数据来自这儿。  

      

    备注:  

      

    1.这种方法适合小额数据的迁移,只能在SQL*PLUS中运行.  

      

    2.这种方法不能copy大对象的表,不然会抛异常"CPY0012: Object datatypes cannot be copied"  

      

      

    1.2 使用范例  

    下面我们通过几个例子来看一下SQL*Plus Copy 命令的使用:  

      

    1.2.1 在同一个服务器的同一个Schema中复制数据:  

    同时指定From database和To database  

    SQL> copy from scott/tiger@lsj to scott/tiger@lsj create dept1 using select * from dept;  

    只指定From Database   

    SQL> copy from scott/tiger@lsj create dept2 using select * from dept; 

    只指定To Database   

    SQL> copy to scott/tiger@lsj create dept3 using select * from dept;  

      

    1.2.2 在同一个服务器的不同Schema中复制数据:  

    这种情况下必须同时指定From Database和To Database  

    SQL> copy from scott/tiger@lsj to lsjdemo/lsjdemo@lsj create dept using select * from dept;  

    注意这种情况下,using select * from dept 中并不需要使用scott.demp的形式。  

      

    1.2.3 在不同的服务器间复制数据:  

    SQL> conn lsj/lsj@sunserve  

    已连接。  

    SQL> copy from scott/tiger@lsj to lsj/lsj@sunserve create dept using select * from dept;  

    2.4 性能实验结果  

    实验数据:  

    记录数:5,082,500  

    数据量:504M  

    实验结果  

      

    方案------------------------执行时间(秒) ---------Undo(M) ------Redo(M)  

    Copy command -------------520.51----------------------0 ---------------- 592  

    Insert into…select …---- 631.64 ------------------345 -------------1720   

      

    Create Table…------------- 244.79 --------------------0 ----------------515  

      

    2.总结  

      

     Create Table…as select…是最快的,而且生成的Undo和Redo信息最少,所以只要可能,请尽量使用这种方案。但这种方案有一定的限制,即目标表必须是不存在的,不能用它向已有的目标表中追加记录。  

     Insert into … select … 是最慢的,而且生成最多的Undo和Redo信息,对I/O的压力最大,优势在于大家对它比较熟悉,使用起来比较简单,适合于处理少量的数据,若要处理大量的数据,不推荐使用这种方案。  

     Copy Command可以处理Create Table不能处理的情况,即向已有的数据表中追加记录,相对于insert来说,效率更高一些,生成更少的Redo信息,不生成Undo信息,所以在执行大量的数据追加时,推荐使用Copy Command命令。  

    二、数据泵导出导入(EXPDP和IMPDP)

    Oracle Database 10g以后引入了最新的数据泵(Data Dump)技术,使DBA或开发人员可以将数据库元数据(对象定义)和数据快速移动到另一个oracle数据库中。
     
    数据泵导出导入(EXPDP和IMPDP)的作用
     
     1、实现逻辑备份和逻辑恢复。
     
     2、在数据库用户之间移动对象。
     
     3、在数据库之间移动对象
     
     4、实现表空间搬移。

    数据泵导出导入与传统导出导入的区别:
     
    在10g之前,传统的导出和导入分别使用EXP工具和IMP工具,从10g开始,不仅保留了原有的EXP和IMP工具,还提供了数据泵导出导入工具EXPDP和IMPDP.使用EXPDP和IMPDP时应该注意的事项;
     
    EXP和IMP是客户段工具程序,它们既可以在客户端使用,也可以在服务器段使用。
     
    EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用,不能在客户端使用
     
    IMP只适用于EXP导出文件,不适用于EXPDP导出文件;IMPDP只适用于EXPDP导出文件,而不适用于EXP导出文件。
     
     
    今天我在导入同事给我的数据文件时,总是报IMP-00038错误,提示,无法转换为环境字符集句柄,造成这种错误的原因一般是数据库版本不匹配,但是我们使用的都是oracle11g,就排除了这种可能。最后发现原因是他是使用数据泵导出的数据文件,而我使用传统imp命令导入是不可以的,后续改为使用impdp数据泵导入成功。
     
    下面是我使用数据泵导入数据文件的完整过程:
     
    1、使用system用户登录数据库,创建新用户usertest(新建用户时用户名最好和数据文件导出时的用户名相同),表空间可以使用系统默认的也可以自己新建一个表空间。sql代码如下:
     
    新建用户使用oracle默认表空间:
    create user usertest identified by usertest; 
     
    新建表空间:
    create tablespace user_all 
    datafile 'D:/dev/oracle/tablespace/user_all.dbf'
    size 300M   
    autoextend on   
    next 50M   
    maxsize unlimited 
     
    新建用户(设置默认表空间):
    create user usertest identified by usertest default tablespace user_all;
     
    2、对新建的用户赋权限,dba、connect、resource。sql代码如下:

    grant connect, resource,dba to usertest;
     
    3、为数据库导入导出,新建目录文件 如dumpdir
     
    create directory 目录名称 as '数据库服务器上的一个目录',如:
    create directory dumpdir as 'd:服务器目录名';
    将导入或导出的文件放在这个目录下
     
    4、为此用户的导入导出目录赋读写权限
    grant read,write on directory dumpdir to usertest;

     
    5、导出及导入
    以SID=orcl,导出dmp的账号为usertest,导入dmp的账号为usertest为例。

     
    若将数据从sfz中导出:
    expdp usertest/usertest@orcl directory=dumpdir  dumpfile=导出文件名

     
    导入到usertest中:
    impdp usertest/usertest@orcl directory=dumpdir  dumpfile=导出文件名.dmp
     
    导入导出用户名最好相同,用户名不同时,还需要做个映射
     
    remap_schema=test:usertest 

     
    注意在使用本地数据库时,要启动以下oracle服务:
     
    OracleOraDb11g_home1TNSListener
    OracleServiceORCL

     
    如果只是连接远程服务器上的数据库,仅使用PL/SQL工具,那么可以把服务全停,这样能省点内存。

    三、oracle中exp,imp(导入,导出)

    今天说说Oracle数据库的导入(imp.exe)和导出(exp.exe)命令的使用,我们的电脑里面安装完Oracle或OracleClient的时候,在我们的安装目录里面就有这两个命令了,一般是在你的Oracle安装目录下面的bin文件夹下面会有exp.exe和imp.exe这两个文件,它们都是在命令行下运行,首先打开你的CMD程序,然后切换到Oracle的bin目录下面。下面就看看这两个命令的具体用法:

    基本语法和实例: 
        1、EXP: 
          有三种主要的方式(完全、用户、表) 
          1、完全: 
              EXP SYSTEM/MANAGER BUFFER=64000 FILE=C:FULL.DMP FULL=Y 
              如果要执行完全导出,必须具有特殊的权限 
          2、用户模式: 
              EXP SONIC/SONIC    BUFFER=64000 FILE=C:SONIC.DMP OWNER=SONIC 
              这样用户SONIC的所有对象被输出到文件中。 
          3、表模式:
              EXP SONIC/SONIC    BUFFER=64000 FILE=C:SONIC.DMP OWNER=SONIC TABLES=(SONIC) 
              这样用户SONIC的表SONIC就被导出 
        2、IMP: 
          具有三种模式(完全、用户、表) 
          1、完全: 
              IMP SYSTEM/MANAGER BUFFER=64000 FILE=C:FULL.DMP FULL=Y 
          2、用户模式: 
              IMP SONIC/SONIC    BUFFER=64000 FILE=C:SONIC.DMP FROMUSER=SONIC TOUSER=SONIC 
              这样用户SONIC的所有对象被导入到文件中。必须指定FROMUSER、TOUSER参数,这样才能导入数据。 
          3、表模式: 
              EXP SONIC/SONIC    BUFFER=64000 FILE=C:SONIC.DMP OWNER=SONIC TABLES=(SONIC) 
              这样用户SONIC的表SONIC就被导入。


    ORACLE数据库有两类备份方法。第一类为物理备份,该方法实现数据库的完整恢复,但数据库必须运行在归挡模式下(业务数据库在非归挡模式下运行),且需要极大的外部存储设备,例如磁带库;第二类备份方式为逻辑备份,业务数据库采用此种方式,此方法不需要数据库运行在归挡模式下,不但备份简单,而且可以不需要外部存储设备。
      
      数据库逻辑备份方法
      
      ORACLE数据库的逻辑备份分为三种模式:表备份、用户备份和完全备份。
      
      表模式
      
      备份某个用户模式下指定的对象(表)。业务数据库通常采用这种备份方式。
      
      若备份到本地文件,使用如下命令:
      
      exp icdmain/icd rows=y indexes=n compress=n buffer=65536
      feedback=100000 volsize=0
      file=exp_icdmain_csd_yyyymmdd.dmp
      log=exp_icdmain_csd_yyyymmdd.log
      tables=icdmain.commoninformation,icdmain.serviceinfo,icdmain.dealinfo
      
      若直接备份到磁带设备,使用如下命令:
      exp icdmain/icd rows=y indexes=n compress=n buffer=65536
      feedback=100000 volsize=0
      file=/dev/rmt0
      log=exp_icdmain_csd_yyyymmdd.log
      tables=icdmain.commoninformation,icdmain.serviceinfo,icdmain.dealinfo
      
      注:在磁盘空间允许的情况下,应先备份到本地服务器,然后再拷贝到磁带。出于速度方面的考虑,尽量不要直接备份到磁带设备。
      
      用户模式
      
      备份某个用户模式下的所有对象。业务数据库通常采用这种备份方式。
      若备份到本地文件,使用如下命令:
      exp icdmain/icd owner=icdmain rows=y indexes=n compress=n buffer=65536
      feedback=100000 volsize=0
      file=exp_icdmain_yyyymmdd.dmp
      log=exp_icdmain_yyyymmdd.log
      若直接备份到磁带设备,使用如下命令:
      exp icdmain/icd owner=icdmain rows=y indexes=n compress=n buffer=65536
      feedback=100000 volsize=0
      file=/dev/rmt0
      log=exp_icdmain_yyyymmdd.log
      注:如果磁盘有空间,建议备份到磁盘,然后再拷贝到磁带。如果数据库数据量较小,可采用这种办法备份。

      以下为详细的导入导出实例:

      一、数据导出:

      1、 将数据库TEST完全导出,用户名system 密码manager 导出到D:daochu.dmp中

      exp system/manager@TEST file=d:daochu.dmp full=y

      2、 将数据库中system用户与sys用户的表导出

      exp system/manager@TEST file=d:daochu.dmp owner=(system,sys)

      3、 将数据库中的表table1 、table2导出

      exp system/manager@TEST file=d:daochu.dmp tables=(table1,table2)

      4、 将数据库中的表table1中的字段filed1以"00"打头的数据导出

      exp system/manager@TEST file=d:daochu.dmp tables=(table1) query=" where filed1 like '00%'"

      上面是常用的导出,对于压缩我不太在意,用winzip把dmp文件可以很好的压缩。

      不过在上面命令后面 加上 compress=y  就可以了

      二、数据的导入

       1、将D:daochu.dmp 中的数据导入 TEST数据库中。

      imp system/manager@TEST  file=d:daochu.dmp

      上面可能有点问题,因为有的表已经存在,然后它就报错,对该表就不进行导入。

      在后面加上 ignore=y 就可以了。

      2 将d:daochu.dmp中的表table1 导入

      imp system/manager@TEST  file=d:daochu.dmp  tables=(table1)

      基本上上面的导入导出够用了。不少情况我是将表彻底删除,然后导入。

      注意:

      如果你的密码中包含特殊字符,在Windows下就需要用三个双引号扩起来,如:
      exp skytf/"""#$adf`%6^=dfom"""@skytf buffer=52428800 file=skytf.dmp

      如果是在Linux系统下,则密码用一对双引号, 整体userid和password用对单引号括住,如:
      exp 'skytf/"?`}:=*H"@skytf'"<akJWI-q-@#<>?`}:Q*H"@skytf' DIRECT=Y buffer=52428800 FEEDBACK=10000 statistics=none file=skytf.dmp

    密码中包含特殊字符的使用,具体请看《Oracle密码中含有特殊字符时exp,imp的使用》文章

      你要有足够的权限,权限不够它会提示你。

      数据库时可以连上的。可以用tnsping TEST 来获得数据库TEST能否连上。

    出处:http://www.cnblogs.com/yugen/archive/2010/07/25/1784763.html

    ============================================================

    假设我如此写导出语句:exp aaa/abc@oracle file=a.dmp full=y; 与 exp aaa/abc@oracle file=a.dmp  (即不加full=y语句)导出的数据文件有什么区别呢?
    (假设在数据库实例中还有bbb、ccc、ddd用户;数据库还有ora、oracl实例)能说得详细一些吗?谢谢了!!

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

    1.如果加上“full=y”,将整个数据库全部导出,需要特殊的权限(具体什么权限没研究过),一般用system用户就足够了,普通用户是不可以的

    2.不加“full=y”,默认导出连接数据库的用户数据库对象,比如:exp aaa/abc@oracle file=a.dmp,导出aaa模式下的所有数据库对象

    3.你说的有多个用户,可以使用system来指定导出哪个用户的数据库对象,比如:exp aaa/abc@oracle file=a.dmp owner=(bbb,ccc),普通用户是不可以指定owner的

    4.数据有多个实例的情况,这个要看你“@”后面是什么,如果@oracle,则在oracle实例上进行导出,@ora,则在ora实例上进行导出

    FULL  导出整个数据库   默认是禁止的 

    不加的就是不导出整个数据库  只导出该用户下的数据   那么bbb用户的数据就不会导出来。

    可以按下面测试:

    exp aaa/abc@oracle file=a.dmp full=y;

    exp aaa/abc@oracle file=b.dmp;

    出处:http://zhidao.baidu.com/link?url=hBYk833zlWqeiba7PeThMkhZ84gzYutLMDVlOy25rlILwlNyd0qc8RhZbF7fKofva5VN5DHRUSxaOhJ01tZI2_

    四、exp/imp和expdp/impdp在功能上的区别

    Oracle10g提出的数据泵技术,在以下几个方面优于exp/imp命令:

      1、数据泵工具运行于服务器端,相比客户端的exp/imp其性能更好,并能实现exp/imp的全部功能。

      2、通过使用exclude,include,content等参数,数据泵可以为数据及数据对象提供更细微级别的选择性。

      3、通过设定数据库版本号,数据泵可以兼容老版本的数据库系统。

      4、并行执行。

      5、通过estimate_only参数,数据泵可以预估导出作业所需的磁盘空间。

      6、支持分布式环境中通过数据库连接实现导入导出。

      7、支持导入时重新映射功能(即将对象导入到新的目标数据文件、架构及表空间等)。

      8、支持元数据压缩及数据采样。

  • 相关阅读:
    C知识(#一些笔记)
    我整理的Python规则(2)
    我整理的Python代码规则
    教你如何通俗易懂的了解深度学习知识
    c#中委托和事件(续)(转)
    c#中的委托和事件(转)
    .Net neatupload上传控件实现文件上传的进度条
    C#常用日期格式处理转换[C#日期格式转换大全
    C#string常用函数总结
    数据库08版本如何移动到05的数据中
  • 原文地址:https://www.cnblogs.com/qiuhong10/p/7909992.html
Copyright © 2020-2023  润新知