oracle导出所有表的表结构命令(oracle导出表数据语句)

oracle11g数据库导入导出:①:传统方式——exp(导出)和(imp)导入:②:数据泵方式——expdp导出和(impdp)导入;③:第三方工具——PL/sqlDevelpoer;一、什么是数
oracle11g数据库导入导出:<span>①:传统方式——exp(导出)和(imp)导入:</span><span>②:数据泵方式——expdp导出和(impdp)导入;</span><span>③:第三方工具——PL/sql Develpoer;</span>

一、什么是数据库导入导出?

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

二、二者优缺点描述:

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

三、特别强调:

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

四、二者的导入导出方法:

1、传统方法:<span>通用命令:exp(imp)  username/password@SERVICENAME:1521 file=\"e:\\temp.dmp\" full = y;</span><span>数据库导出举例:</span>exp xinxiaoyong/123456@127.0.0.1:1521 file=<span>\"e:\\temp.dmp\"</span> full = y;<span>exp:导出命令,导出时必写。</span><span>imp:导入命令,导入时必写,每次操作,二者只能选择一个执行。</span><span>username:导出数据的用户名,必写;</span><span>password:导出数据的密码,必写;</span><span>@:地址符号,必写;</span><span>SERVICENAME:Oracle的服务名,必写;</span><span>1521:端口号,1521是默认的可以不写,非默认要写;</span>file=<span>\"e:\\temp.dmp\"</span> : 文件存放路径地址,必写;full=y :表示全库导出。可以不写,则默认为no,则只导出用户下的对象;方法细分:1.完全导入导出:exp(imp)  username/password@SERVICENAME:1521 file=<span>\"e:\\temp.dmp\"</span> full = y;
<span>2.</span>部分用户表<span>table</span>导入导出:<span>exp</span>(imp)  username/password@SERVICENAME:<span>1521</span> file=<span>\"e:\\temp.dmp\"</span> tabels= (table1,table2,table3,...);
<span>3.</span>表空间tablespaces导入导出:<span>//一个数据库实例可以有N个表空间(tablespace),一个表空间下可以有N张表(table)。</span><span>exp</span>(imp)  username/password@SERVICENAME:<span>1521</span> file=<span>\"e:\\temp.dmp\"</span> tablespaces=   (tablespace1,tablespace2,tablespace3,...);
<span>4</span>.用户名username对象导入导出:<span>exp</span>(imp)  username/password@SERVICENAME:<span>1521</span> file=<span>\"e:\\temp.dmp\"</span>                                                                                owner(username1,username2,username3);
2、数据泵方法:<span>创建directory:</span>expdp(impdp) username/password@SERVICENAME:1521 schemas=username                                                                       dumpfile=file1.dmp logfile=file1.log directory=testdata1 remap_schema=test:test;<span>数据库导出举例:</span>expdp xinxiaoyong/123456@127.0.0.1:1521 schemas=xinxiaoyong dumpfile=test.dmp logfile=test.log directory=testdata1;<span>exp:导出命令,导出时必写。</span><span>imp:导入命令,导入时必写,每次操作,二者只能选择一个执行。</span><span>username:导出数据的用户名,必写;</span><span>password:导出数据的密码,必写;</span><span>@:地址符号,必写;</span><span>SERVICENAME:Oracle的服务名,必写;</span><span>1521:端口号,1521是默认的可以不写,非默认要写;</span>schemas:导出操作的用户名;dumpfile:导出的文件;<span>logfile:导出的日志文件,可以不写;</span><span>directory:创建的文件夹名称;</span>remap_schema=源数据库用户名:目标数据库用户名,二者不同时必写,相同可以省略;1.查看表空间:select * from dba_tablespaces;2.查看管理理员目录(同时查看操作系统是否存在,因为Oracle并不关心该目录是否存在,如果不存                                                    在,则出错)。select * from dba_directories;
3.创建逻辑目录,该命令不会在操作系统创建真正的目录,最好以system等管理员创建。 <span>create</span> <span>directory</span> testdata1 <span>as</span> <span>\'d:\\test\\dump\'</span>;4.给xinxiaoyong用户赋予在指定目录的操作权限,最好以system等管理员赋予。//xinxiaoyong 是用户名(123456是用户密码)<span>grant</span> <span>read</span>,write <span>on</span> <span>directory</span> testdata1 <span>to</span> xinxiaoyong;
<span>5</span><span>.导出数据</span><span>1</span><span>)按用户导</span> <span>expdp</span> <span>xinxiaoyong/123456@orcl</span> <span>schemas=xinxiaoyong</span>                                                                                           <span>dumpfile=expdp.dmp</span> <span>directory=testdata1;</span><span>2</span><span>)并行进程parallel</span> <span>expdp</span> <span>xinxiaoyong/123456@orcl</span> <span>directory=testdata1</span>                                                                                    <span>dumpfile=xinxiaoyong3.dmp</span> <span>parallel=40</span> <span>job_name=xinxiaoyong3</span><span>3</span><span>)按表名导</span> <span>expdp</span> <span>xinxiaoyong/123456@orcl</span> <span>tables=emp,dept</span> <span>dumpfile=expdp.dmp</span>                                                                <span>directory=testdata1;</span><span>4</span><span>)按查询条件导</span> <span>expdp</span> <span>xinxiaoyong/123456@orcl</span> <span>directory=testdata1</span>                                                                                            <span>dumpfile=expdp.dmp</span> <span>tables=emp</span> <span>query=\'WHERE</span> <span>deptno=20\';</span><span>5</span><span>)按表空间导</span> <span>expdp</span> <span>system/manager</span> <span>directory=testdata1</span> <span>dumpfile=tablespace.dmp</span>                                                                    <span>tablespaces=temp,example;</span><span>6</span><span>)导整个数据库</span> <span>expdp</span> <span>system/manager</span> <span>directory=testdata1</span> <span>dumpfile=full.dmp</span> <span>FULL=y;</span><span>6</span><span>.还原数据</span><span>1</span><span>)导到指定用户下</span> <span>impdp</span> <span>xinxiaoyong/123456</span> <span>directory=testdata1</span> <span>dumpfile=expdp.dmp</span>                                                              <span>schemas=xinxiaoyong;</span><span>2</span><span>)改变表的owner</span> <span>impdp</span> <span>system/manager</span> <span>directory=testdata1</span> <span>dumpfile=expdp.dmp</span>                                                               <span>tables=xinxiaoyong.dept</span> <span>remap_schema</span> <span>=xinxiaoyong:system;</span><span>3</span><span>)导入表空间</span> <span>impdp</span> <span>system/manager</span> <span>directory=testdata1</span> <span>dumpfile=tablespace.dmp</span>                                                         <span>tablespaces=example;</span><span>4</span><span>)导入数据库</span> <span>impdb</span> <span>system/manager</span> <span>directory=dump_dir</span> <span>dumpfile=full.dmp</span> <span>FULL=y;</span><span>5</span><span>)追加数据</span> <span>impdp</span> <span>system/manager</span> <span>directory=testdata1</span> <span>dumpfile=expdp.dmp</span>                                                         <span>schemas=system</span>  <span>table_exists_action;</span><span>3</span><span>、PLSQL方法:</span><span>登录plsql工具,所使用用户为源数据库有导出权限(exp_full_database,dba等)的用户。</span>   <span>1</span><span>.导出建表语句(包括存储结构)</span> 

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

oracle导出所有表的表结构命令(oracle导出表数据语句)

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

导出为dmp格式,如下图:

oracle导出所有表的表结构命令(oracle导出表数据语句)

导出为sql格式,如下图:

oracle导出所有表的表结构命令(oracle导出表数据语句)

导出为pde格式,如下图:

oracle导出所有表的表结构命令(oracle导出表数据语句)

提示说明:采用第三方工具导出导入整个数据库的话,耗时较长,一定要有足够的时间来操作(数据量大的话需要好几个小时)。

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

由于水平有限,本文档仅提供参考。如代码有错误之处,请见谅。

另外附上Oracle exp导出数据详细介绍

Oracle exp导出数据

Oracle exp工具可以选择性的导出数据库的对象和表数据,导出DMP文件以备以后进行数据恢复。下面分别讲解如何通过EXP导出数据库的表、方案、表空间、数据库四个不同对象的数据。

使用EXP工具可以使用第三方工具PL/SQL DEVELOPER进行导出,也可以直接通过DOS命令行窗口直接进行导出。

EXP 导出表

进入DOS命令行窗口,输入以下命令:

<span>exp</span> username/password

使用用户名和密码登录,然后按照工具提示,导出对应的表结构数据,具体步骤如下图:

oracle导出所有表的表结构命令(oracle导出表数据语句)

从上图可以看出,我们要导出的是student用户的学生信息表(stuinfo),其中导出的数据文件保存的路径是在d:\\student.dmp。然后通过选择要导出的类型选择导出表(T),再然后按照提示一步一步的进行,就可以导出想要的表结构数据。

但是在实际应用当中,我们一般是直接使用命令语句导出想要的数据对象。不需要这样子一步一步的选择。

EXP导出表数据命令:

<span>exp</span> student/<span>123456</span>@orcl file=d:\\student.dmp tables= stuinfo buffer=<span>4096</span> <span>log</span>=d:\\student.<span>log</span>

结果如下:

oracle导出所有表的表结构命令(oracle导出表数据语句)

命令解析:

1、file指定数据备份文件的保存地址。

2、tables指定要备份的表结构,可以导出多个表,通过(table1,table2…,tablen)进行选择。

3、buffer指定数据缓存区的大小。

4、log指定进行导出的日志文件的保存地址。


EXP导出带条件的表数据:

<span>exp</span> student/<span>123456</span>@orcl file=d:\\student.dmp tables= stuinfo buffer=<span>4096</span> <span>log</span>=d:\\student.<span>log</span> query=<span>\"\'where sex=1\'\"</span>

命令解析:

1、query指定要添加的条件,把表中的数据进行过滤导出。

结果如下:

oracle导出所有表的表结构命令(oracle导出表数据语句)

EXP导出用户

EXP导出用户命令结构:

<span>exp</span> student/<span>123456</span>@orcl file=d:\\student.dmp owner=(student) buffer=<span>4096</span> <span>log</span>=d:\\student.<span>log</span>

命令解析:

1、owner 指定要导出的用户的用户名,但是前提条件是登录的用户得具有访问其它用户对象的权限。一般是使用DBA用户进行登录。可以支持多用户导出,使用逗号“,”进行隔开。

结果如下:

oracle导出所有表的表结构命令(oracle导出表数据语句)

EXP导出表空间

EXP导出表空间命令结构:

<span>exp</span> student/<span>123456</span>@orcl file=d:\\student.dmp tablespaces=(student) buffer=<span>4096</span> <span>log</span>=d:\\student.<span>log</span>

命令解析:

1、tablespaces指定要导出的表空间,但是前提条件是登录的用户得是DBA用户。可以支持多表空间一起导出,使用逗号“,”进行隔开。

结果如下:

oracle导出所有表的表结构命令(oracle导出表数据语句)

EXP导出数据库

EXP导出数据库命令结构:

<span>exp</span> student/<span>123456</span>@orcl file=d:\\student.dmp FULL=Y buffer=<span>4096</span> <span>log</span>=d:\\student.<span>log</span>

命令解析:

1、full=Y指的是要导出的是整个数据库,但是前提条件是登录的用户得是DBA用户。

总结

Oracle使用EXP工具进行导出数据库数据进行备份是数据库管理员经常要做的事情,经常用来做数据迁移和定期的数据备份。

本站部分文章来自网络或用户投稿,如无特殊说明或标注,均为本站原创发布。涉及资源下载的,本站旨在共享仅供大家学习与参考,如您想商用请获取官网版权,如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
科技百科

有关字体设计制作工具(文字特效怎么弄)

2023-12-11 11:32:55

科技百科

MySQL创建存储过程的命令(mysql可以安装在d盘吗)

2023-12-11 11:33:35

搜索