精华内容
下载资源
问答
  • oracle11g数据库导入导出方法教程

    万次阅读 多人点赞 2018-03-04 15:03:09
    oracle11g数据库导入导出: ①:传统方式——exp(导出)和(imp)导入: ②:数据泵方式——expdp导出和(impdp)导入; ③:第三方工具——PL/sql Develpoer;、什么是数据库导入导出oracle11g数据库的导入/导出,...

    oracle11g数据库导入导出:

    ①:传统方式——exp(导出)和(imp)导入:
    ②:数据泵方式——expdp导出和(impdp)导入;
    ③:第三方工具——PL/sql Develpoer;

    一、什么是数据库导入导出?
    oracle11g数据库的导入/导出,就是我们通常所说的oracle数据的还原/备份。
    数据库导入:把.dmp 格式文件从本地导入到数据库服务器中(本地oracle测试数据库中);
    数据库导出:把数据库服务器中的数据(本地oracle测试数据库中的数据),导出到本地生成.dmp格式文件。
    .dmp 格式文件:就是oracle数据的文件格式(比如视频是.mp4 格式,音乐是.mp3 格式);

    二、二者优缺点描述:
    1.exp/imp:
    优点:代码书写简单易懂,从本地即可直接导入,不用在服务器中操作,降低难度,减少服务器上的操作也就                                         保证了服务器上数据文件的安全性。
    缺点:这种导入导出的速度相对较慢,合适数据库数据较少的时候。如果文件超过几个G,大众性能的电                                       脑,至少需要4~5个小时左右。
    2.expdp/impdp:
    优点:导入导出速度相对较快,几个G的数据文件一般在1~2小时左右。
    缺点:代码相对不易理解,要想实现导入导出的操作,必须在服务器上创建逻辑目录(不是真正的目录)。我们                                       都知道数据库服务器的重要性,所以在上面的操作必须慎重。所以这种方式一般由专业的程序人员来完                                           成(不一定是DBA(数据库管理员)来干,中小公司可能没有DBA)。
    3.PL/sql Develpoer:
    优点:封装了导入导出命令,无需每次都手动输入命令。方便快捷,提高效率。
    缺点:长时间应用会对其产生依赖,降低对代码执行原理的理解。

    三、特别强调:
    目标数据库:数据即将导入的数据库(一般是项目上正式数据库);
    源数据库:数据导出的数据库(一般是项目上的测试数据库);
    1.目标数据库要与源数据库有着名称相同的表空间。
    2.目标数据在进行导入时,用户名尽量相同(这样保证用户的权限级别相同)。
    3.目标数据库每次在进行数据导入前,应做好数据备份,以防数据丢失。
    4.使用数据泵时,一定要现在服务器端建立可用的逻辑目录,并检查是否可用。
    5.弄清是导入导出到相同版本还是不同版本(oracle10g版本与oracle11g版本)。
    6.目标数据导入前,弄清楚是数据覆盖(替换),还是仅插入新数据或替换部分数据表。
    7.确定目标数据库磁盘空间是否足够容纳新数据,是否需要扩充表空间。
    8.导入导出时注意字符集是否相同,一般Oracle数据库的字符集只有一个,并且固定,一般不改变。
    9.导出格式介绍:
       Dmp格式:.dmp是二进制文件,可跨平台,还能包含权限,效率好; 
       Sql格式:.sql格式的文件,可用文本编辑器查看,通用性比较好,效率不如第一种,
    适合小数据量导入导出。尤其注意的是表中不能有大字段 (blob,clob,long),如果有,会报错; 
       Pde格式:.pde格式的文件,.pde为PL/SQL Developer自有的文件格式,只能用PL/SQL Developer工具
    导入导出,不能用文本编辑器查看;
    10.确定操作者的账号权限。

    四、二者的导入导出方法:
    1、传统方法:
    通用命令:exp(imp)  username/password@SERVICENAME:1521 file="e:\temp.dmp" full = y;
    数据库导出举例:

     

    exp xinxiaoyong/123456@127.0.0.1:1521 file="e:\temp.dmp" full = y;

    exp:导出命令,导出时必写。
    imp:导入命令,导入时必写,每次操作,二者只能选择一个执行。
    username:导出数据的用户名,必写;
    password:导出数据的密码,必写;
    @:地址符号,必写;
    SERVICENAME:Oracle的服务名,必写;
    1521:端口号,1521是默认的可以不写,非默认要写;
    file="e:\temp.dmp" : 文件存放路径地址,必写;
    full=y :表示全库导出。可以不写,则默认为no,则只导出用户下的对象;
    方法细分:
    1.完全导入导出:
    exp(imp)  username/password@SERVICENAME:1521 file="e:\temp.dmp" full = y;
    2.部分用户表table导入导出:
    exp(imp)  username/password@SERVICENAME:1521 file="e:\temp.dmp" tabels=                                                                  (table1,table2,table3,...);
    3.表空间tablespaces导入导出:
    //一个数据库实例可以有N个表空间(tablespace),一个表空间下可以有N张表(table)。
    exp(imp)  username/password@SERVICENAME:1521 file="e:\temp.dmp" tablespaces=                                                         (tablespace1,tablespace2,tablespace3,...);
    4.用户名username对象导入导出:
    exp(imp)  username/password@SERVICENAME:1521 file="e:\temp.dmp"                                                                                owner(username1,username2,username3);

    2、数据泵方法:
    创建directory:
    expdp(impdp) username/password@SERVICENAME:1521 schemas=username                                                                       dumpfile=file1.dmp logfile=file1.log directory=testdata1 remap_schema=test:test;
    数据库导出举例:
    expdp xinxiaoyong/123456@127.0.0.1:1521 schemas=xinxiaoyong dumpfile=test.dmp 
    logfile=test.log directory=testdata1;

    exp:导出命令,导出时必写。
    imp:导入命令,导入时必写,每次操作,二者只能选择一个执行。
    username:导出数据的用户名,必写;
    password:导出数据的密码,必写;
    @:地址符号,必写;
    SERVICENAME:Oracle的服务名,必写;
    1521:端口号,1521是默认的可以不写,非默认要写;
    schemas:导出操作的用户名;
    dumpfile:导出的文件;
    logfile:导出的日志文件,可以不写;
    directory:创建的文件夹名称;
    remap_schema=源数据库用户名:目标数据库用户名,二者不同时必写,相同可以省略;
    1.查看表空间:
    select * from dba_tablespaces;
    2.查看管理理员目录(同时查看操作系统是否存在,因为Oracle并不关心该目录是否存在,如果不存                                                    在,则出错)。
    select * from dba_directories;
    3.创建逻辑目录,该命令不会在操作系统创建真正的目录,最好以system等管理员创建。 
    create directory testdata1 as 'd:\test\dump';
    4.给xinxiaoyong用户赋予在指定目录的操作权限,最好以system等管理员赋予。
    //xinxiaoyong 是用户名(123456是用户密码)
    grant read,write on directory testdata1 to xinxiaoyong;
    5.导出数据

     

     

    1)按用户导 expdp xinxiaoyong/123456@orcl schemas=xinxiaoyong                                                                                           dumpfile=expdp.dmp directory=testdata1;

    2)并行进程parallel expdp xinxiaoyong/123456@orcl directory=testdata1                                                                                    dumpfile=xinxiaoyong3.dmp parallel=40 job_name=xinxiaoyong3
    3)按表名导 expdp xinxiaoyong/123456@orcl tables=emp,dept dumpfile=expdp.dmp                                                                directory=testdata1;
    4)按查询条件导 expdp xinxiaoyong/123456@orcl directory=testdata1                                                                                            dumpfile=expdp.dmp tables=emp query='WHERE deptno=20';
    5)按表空间导 expdp system/manager directory=testdata1 dumpfile=tablespace.dmp                                                                    tablespaces=temp,example;
    6)导整个数据库 expdp system/manager directory=testdata1 dumpfile=full.dmp FULL=y;
    6.还原数据
    1)导到指定用户下 impdp xinxiaoyong/123456 directory=testdata1 dumpfile=expdp.dmp                                                              schemas=xinxiaoyong;
    2)改变表的owner impdp system/manager directory=testdata1 dumpfile=expdp.dmp                                                               tables=xinxiaoyong.dept remap_schema =xinxiaoyong:system;
    3)导入表空间 impdp system/manager directory=testdata1 dumpfile=tablespace.dmp                                                         tablespaces=example;
    4)导入数据库 impdb system/manager directory=dump_dir dumpfile=full.dmp FULL=y;
    5)追加数据 impdp system/manager directory=testdata1 dumpfile=expdp.dmp                                                         schemas=system  table_exists_action;

    3、PLSQL方法:
    登录plsql工具,所使用用户为源数据库有导出权限(exp_full_database,dba等)的用户。 
      1.导出建表语句(包括存储结构) 

     

     

      导出步骤tools ->export user object,选择要导出的对象,导出.sql格式文件并等待导出完成,如 下图:

     

                                                

     

    导出数据文件 ;
       2.导出步骤tools ->export tables,选择要导出的表及导出的格式进行导出。 

     

       导出为dmp格式,如下图:

    导出为sql格式,如下图: 

    导出为pde格式,如下图: 

     

                提示说明:采用第三方工具导出导入整个数据库的话,耗时较长,一定要有足够

     

                            的时间来操作(数据量大的话需要好几个小时)。

     

    3.导入建表语句 
       导入步骤tools->import tables->SQL Inserts 导入.sql文件 
    4.导入数据; 
       tools->import talbes,然后再根据导出的数据格式选择导入dmp文件,或者sql文件,
    或者pde文件。 
       提示说明:导入之前最好把以前的表删除,当然导入另外数据库除外。 
          另外导入时当发现进度条一直卡在一个点,而且导出的文件不再增大时,甚至是提示程序
    未响应,千万不要以为程序卡死了,这个导入导出就是比较缓慢,只要没有提示报错,

     

    或者导入完成就不要停止程序。

    提示:创建数据库,表空间这里略过,本文主要讨论数据的导入导出,如果对此感觉稍有遗漏,尽请见谅。由于水平有限,本文档仅提供参考。如代码有错误之处,请见谅。如果有更好的开发经验,感谢回复。谢谢观看!!!;

    展开全文
  • oracle数据库的导出,然后建用户说明,以及导出SQL脚本
  • Oracle 11g导出空表、少表的解决办法  ORACLE 11G中有个新特性,当表无数据时,不分配segment,以节省空间。 解决方法:  1)insert行,再rollback就产生segment了  该方法是在在空表中插入数据,再删除,则...
  • //使用方法 sql> 输入如↓注意文件写入权限 SET echo off; SET heading off; SET feedback off; spool /home/oracle/temp.txt; select text from user_source; spool off;
    //使用方法   sql> 输入如↓注意文件写入权限
    SET echo off;
    SET heading   off;
    SET feedback   off;
    spool /home/oracle/temp.txt;
    select   text   from   user_source;
    spool off;
    

    原理是将之后输入的select语句保存为文件
    效果图如下
    在这里插入图片描述

    展开全文
  • Oracle11g导出空表

    2015-03-23 14:27:02
    导出数据时会出现空表不能导出的问题,这是因为:1、Oracle11g 默认对空表不分配 segment,故使用 exp 导出 Oracle11g 数据库时,空表不 会导出。 2、默认设置 deferred_segment_creation 参数为 TRUE,空表不分配 ...

    Oracle11g 在使用 exp导出数据时会出现空表不能导出的问题,这是因为:1Oracle11g默认对空表不分配 segment,故使用exp 导出Oracle11g 数据库时,空表不

    会导出。
    2、默认设置deferred_segment_creation参数为 TRUE,空表不分配segment处理方法:

    sqlplus中,执行如下命令:

    SQL>alter system set deferred_segment_creation=false;

    查看:

    SQL>show parameter deferred_segment_creation;

    该值设置后只对后面新增的表产生作用,对之前建立的空表不起作用。

    3、可以使用手工为空表分配Extent 的方式,来解决导出之前建立的空表的问题。说明如下:

    3.1 使用ALLOCATE EXTENT 的说明

    使用 ALLOCATE EXTENT可以为数据库对象分配 Extent。其语法如下:

    -----------
    ALLOCATE EXTENT { SIZE integer [K | M] | DATAFILE 'filename' | INSTANCE integer }-----------

    可以针对数据表、索引、物化视图等手工分配Extent

    ALLOCATE EXTENT 使用样例:

    ALLOCATE EXTENT
    ALLOCATE EXTENT(SIZE integer [K | M])ALLOCATE EXTENT(DATAFILE 'filename')ALLOCATE EXTENT(INSTANCE integer)ALLOCATE EXTENT(SIZE integer [K | M]ALLOCATE EXTENT(SIZE integer [K | M]

    针对数据表操作的完整语法如下:
    

    DATAFILE 'filename')INSTANCE integer)

    -----------
    ALTER TABLE [schema.]table_name ALLOCATE EXTENT [({ SIZE integer [K | M] |

    DATAFILE 'filename' | INSTANCE integer})]-----------

    故,需要构建如下样子简单的 SQL 命令:

    -----------
    alter table aTabelName allocate extent-----------

    3.2 构建对空表分配空间的SQL 命令,

    查询当前用户下的所有空表(一用户最好默认表空间)。命令如下:

    -----------
    SQL>select table_name from user_tables where NUM_ROWS=0;-----------

    上述查询,可以构建针对空表分配空间的命令语,如下:

    -----------

    SQL>Select 'alter table '||table_name||' allocate extent;' from user_tables wherenum_rows=0

    -----------

    批量输上述SQL ,建立C:\createsql.sql,其内容如下:

    -----------
    set heading off;
    set echo off;
    set feedback off;
    set termout on;
    spool C:\allocate.sql;
    Select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0;spool off;
    -----------

    执行 C:\createsql.sql,命令如下:-----------
    SQL>@ C:\createsql.sql;
    -----------

    执行完后,得到C:\allocate.sql 文件打开文件会看,已经得到对所有空表分配空间的命令SQL

    3.4 执行SQL 命令,对空表分配空间:

    执行 C:\allocate.sql,命令如下:-----------
    SQL>@ C:\allocate.sql;
    -----------

    执行完,表已更改


    3.4 时执行exp 命令,把包括空表在的所有表,正常导出。

    另外:Oracle11g中,对密码是大小写敏感的,即密码中的字母是区大小写的。在Oracle10g 以前,密码中的字母大小写无。 

    展开全文
  • 《oracle笔记》oracle导出sql文件

    千次阅读 2019-05-13 14:07:13
    Navicat for Oracle 导出表结构: 1. 带schema, 2. 表名带有双引号 3. 带索引和约束 导出表数据: Aqua Data Studio ...5. 个表个文件,导出多个文件. Aqua Data Studio 只导出数据. ...

    Navicat for Oracle

     

    导出表结构 :

    1. 带schema,

    2. 表名带有双引号

    3. 带索引和约束

    导出表数据:

    Aqua Data Studio

    1. 带 schema

    2. 无双引号

    3. insert语句指定字段插入

    4.不带索引和约束

    5. 一个表一个文件,导出多个文件.

    Aqua Data Studio 只导出数据.

     

     

    通过cmd命令合并:  copy *.sql   all.sql

     

     

     

    导出blob大字段

    mkdir /usr/bak
    chmod 777 -R /usr/bak
    
    sqlplus sys/oracle as sysdba
    
    create or replace directory  mydir as '/usr/bak';
    
    
    expdp yue7/123456  directory=mydir  dumpfile=OAUTH_CODE.dmp   TABLEs=OAUTH_CODE 

    导入blob大字段

    create or replace directory  backdir as '/home/oracle';      ----创建路径
    grant read,write on directory backdir  to yue7; 
    
    impdp yue7/oracle DIRECTORY=backdir DUMPFILE=OAUTH_CODE.dmp transform=segment_attributes:n tables=OAUTH_CODE REMAP_SCHEMA=poep7:yue7

     

    展开全文
  • Oracle11g导出dmp有空表今天在用plsql导出dmp的时候命令行输出有些表显示没有导出成功,查了下这些表发现都是空表,也就是说plsql在导出这些表的时候空表是不导出的。经过查询,以下为解决方案: 首先使用下面的sql...
  • 在项目中遇到,导出excel报错的问题 @clob的错误,错误码忘记了,抱歉 在导出时用到了wm_concat...改为如下拼接方式,listagg(),返回字符串,但是需要oracle11g上才支持,并且不支持distinct, 拼接长度不能大于4000,函
  • Oracle数据库中导出数据库对象创建和申明的SQL脚本
  • ------解决oracle11g导出表空间存在空表问题: ------执行下面代码,使oracle以后建立表时默认分配空间; alter system set deferred_segment_creation=false; ------在目标数据库新建 E:\sql_allocate.sql;文件 -...
  • oracle11g导出dmp文件时不能导出空表,导致缺表
  • ORACLE11g导入导出数据

    2016-06-21 12:03:42
    oracle11g 数据库的导入导出
  • Oracle11g导出空表方法

    千次阅读 2018-02-09 11:04:00
    oracle11g增加了新属性deferred_segment_creation,boolean型,默认为true,定义了是否延迟分配segment。 值为true,创建表为空表(只有表结构,没有数据)时,就会暂时不分配segment。这样做可以提高建表效率,...
  • oracle11g 导入导出

    2015-10-14 22:04:21
    导出oracle数据库 1.修改tnsnames.ora文件,将localhost本地地址改为远程地址。 # tnsnames.ora Network Configuration File: E:\Ksoftware\oracle_install\product\11.2.0\dbhome_1\network\admin\tnsnames....
  • 查资料发现oracle11g增加了个新特性 "deferred_segment_creation"含义是段延迟创建,默认是true。也就是说没有创建段的表格是不能被exp导出到dmp文件中的。所以需要我们手动为空表创建段。 二、工具与环境 1....
  • oracle sqlplus命令行导出sql结果到文件

    千次阅读 2020-03-28 07:46:47
    导出sql结果 使用spool 即可。 spool ttt.txt; # select 1 from dual; # 查询语句 spool off; # 关闭缓冲,并导出内容到文件 小提示: spool ttt.txt; 文件不存在会新建,存在的话,直接清空。 执行sql并不会输出...
  • 3.sqlplus登录,通过SQL-> d:/*****_export.sql,It's done! /**********************************************华丽的分割线****************************************************/ 1.建立表空间 2....
  • 1、Oracle11g默认对空表不分配segment,故使用exp导出Oracle11g数据库时,空表不会导出。 2、设置deferred_segment_creation 参数为FALSE后,无论是空表还是非空表,都分配segment。 在sqlplus中,执行如下命令:...
  • 、导入 基本方法:将语句copy执行 plsqlDev:导入表——tab为SQL插入页是选择文件导入 二、导出 1、工具 2、导出表(或导出用户对象) 3、选择需要导出的数据对象(表,视图,函数,过程等) 4、tab为SQL...
  • oracle 11G导出空表

    2013-12-30 22:16:20
    1、Oracle11g默认对空表不分配segment,故使用exp导出Oracle11g数据库时,空表不会导出。 2、设置deferred_segment_creation 参数为FALSE后,无论是空表还是非空表,都分配segment。  在sqlplus中,执行如下...
  • 由于导出的该用户的表可能存在空数据表,那么可能就会出现此其异常。 首先: 查看: SQL>show parameter deferred_segment_creation; 如果为TRUE,则将该参数改为FALSE; 在sqlplus中,执行如下命令: SQL>alter ...
  • Oracle使用spool方式导出SQL脚本

    千次阅读 2015-09-09 16:30:30
    下面介绍Oracle导出SQL脚本的实现方法。本方法使用spool。 a. 获取单个的建表和建索引的语法 set heading off;  set echo off;  Set pages 999;  set long 90000;  spool DEPT.sql ...
  • oracle 11g exp导出空表

    千次阅读 2014-02-12 17:14:45
    oracle 11g 默认对空表不分配segment,故使用exp导出Oracle11g数据库时,空表不会导出。默认情况下,deferred_segment_creation 参数为TRUE,将参数 deferred_segment_creation 参数设置为FALSE后,无论是空表还是...
  • 关于oracle 11g导出数据时 报 ORA 1455错误的处理
  • 1. 将dmp文件导入Oracle11g中,用Oracle10g客户端去连接oracle11g,并导出相应的dmp文件。这样就可以导入了 2. 修改dmp文件内容,打开
  • oracle 导入导出sql

    2018-10-10 10:35:58
    导出 : expdp 用户名/密码@192.168.2.139/数据库实例名称 directory=exp_dp dumpfile=备份名称自定义.dmp full=y  导入: impdp 用户名/密码 directory=exp_dp dumpfile... 注意导入导出要创建directory 这个...
  • Oracle 11g导出空表、少表的解决办法,在ORACLE 11G中有个新特性,当表无数据时,不分配segment,以节省空间,所以在导出时不会将空表进行导出,但我们导出是需要所有表的信息的,故而如何解决呢,本人真是针对此问题...
  • Oracle 11G数据库导出完整数据库

    千次阅读 2019-01-17 13:57:55
    Oracle 11G数据库导出完整数据库 oracle11G版本开始,导出数据库的时候,是不会导出空表的,因此需要先执行导出空表的命令,再进行数据导出。 首先通过命令行,登录oracle数据库,sqlplus / as sysdba; 切换到...
  • 原因:在Oracle 11g 默认空表不能导出,因为在11g版本中新添加了个参数deferred_segment_creation,它的意思是段延迟创建;安装数据库后默认是true。可以查看一下,在命令窗口: SQL> show parameter deferred...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 65,503
精华内容 26,201
关键字:

oracle11g导出sql