EXP备份数据库时出现错误提示 EXP-00056: 遇到 ORACLE 错误 29900 同一台机器同一个命令行不知道,求高手

EXP备份数据库时出现错误提示 EXP-00056: 遇到 ORACLE 错误 29900 同一台机器同一个命令行不知道,求高手,第1张

解决办法:

选择和远程服务器相同版本客户端里面的expexe。

至于里面的参数buffer size的话,用默认值也行,假如想快点的话,就设置大一点。例如设置为512000kb,这样假如你本机内存不大的话,可以机器做别的会慢。不过导出的速度快。

用plsql导出dmp格式数据库时,左侧“对象”里面默认选择的是“All object”,记得改为“My object”,然后在选择所有的表右键选择“导出数据”,之后当然是选择oracle导出,除非你不想导出dmp格式文件。因为默认为“All object”时有大量的系统表,这些表导出数据库的时候你是不需要的,而这些系统表数据量很大,导出的话很容易会报错。

原因:

导出用的可执行文件expexe为本地装的oracle服务器端,本地版本高于远程服务器版本。

log:EXP-00056: 遇到 ORACLE 错误 6550 ,

ORA-06550: line 1, column 41:

PLS-00302: component 'SET_NO_OUTLINES' must be declared ,

ORA-06550: line 1, column 15:

PL/SQL: Statement ignored ,

EXP-00000: 导出终止失败 。

oracle安装不全,这个命令在:/opt/oracle/product/1020/db_1/bin目录下,确认一下exp文件是否存在。

概述

简单地说,Linux是一套免费使用和自由传播的类Unix *** 作系统,它主要用于基于Intel x86系列CPU的计算机上。这个系统是由世界各地的成千上万的程序员设计和实现的。其目的是建立不受任何商品化软件的版权制约的、全世界都能自由使用的 Unix兼容产品。

Linux的出现,最早开始于一位名叫Linus Torvalds的计算机业余爱好者,当时他是芬兰赫尔辛基大学的学生。他的目的是想设计一个代替Minix(是由一位名叫Andrew Tannebaum的计算机教授编写的一个 *** 作系统示教程序)的 *** 作系统,这个 *** 作系统可用于386、486或奔腾处理器的个人计算机上,并且具有 Unix *** 作系统的全部功能,因而开始了Linux雏形的设计。

绝大多数基于Linux内核的的 *** 作系统使用了大量的GNU软件,包括了shell程序、工具、程序库、编译器及工具,还有许多其他程序,例如Emacs。正因为如此,GNU计划的开创者理查德·马修·斯托曼博士提议将Linux *** 作系统改名为GNU/Linux。但有些人只把 *** 作系统叫做"Linux"。

Linux的基本思想有两点:第一,一切都是文件;第二,每个软件都有确定的用途,同时它们都尽可能被编写得更好。其中第一条详细来讲就是系统中的所有都归结为一个文件,包括命令、硬件和软件设备、 *** 作系统、进程等等对于 *** 作系统内核而言,都被视为拥有各自特性或类型的文件。至于说Linux是基于Unix的,很大程度上也是因为这两者的基本思想十分相近。

最近用到Oracle导出导入数据,在网上看了别人的一些文章,总结如下:

Oracle导出导出有两中方式:一、利用exp imp导出导入;二、利用Oracel数据泵expdp impdp导出导入。

一、利用exp imp导出导入

exp imp 语法如下:

exp:

1) 将数据库orcl完全导出

exp system/manager@orcl file=d:\orcl_bakdmp full=y

2) 将数据库中system用户的表导出

exp system/manager@orcl file=d:\system_bakdmp owner=system

3) 将数据库中表table1,table2导出

exp system/manager@orcl file=d:\table_bakdmp tables=(table1,table2)

4) 将数据库中的表customer中的字段mobile以"139"开头的数据导出

exp system/manager@orcl file=d:\mobile_bakdmp tables=customer query=\"where mobile like '139%' \"

imp:

1) 将备份文件bakdmp导出数据库

imp system/manager@orcl file=d:\bakdmp

如果数据表中表已经存在,会提示错误,在后面加上ignore=y就可以了。

2) 将备份文件bakdmp中的表table1导入

imp system/manager@orcl file=d:\bakdmp tables=(table1)

exp imp导出导入数据方式的好处是只要你本地安装了Oracle客户端,你就可以将服务器中的数据导出到你本地计算机。同样也可以将dmp文件从你本地导入到服务器数据库中。但是这种方式在Oracle11g版本中会出现一个问题:不能导出空表。Oracle11g新增了一个参数deferred_segment_creation,含义是段延迟创建,默认是true。当你新建了一张表,并且没用向其中插入数据时,这个表不会立即分配segment。

解决办法:

1、设置deferred_segment_creation参数为false后,无论是空表,还是非空表,都分配segment。

在sqlplus中,执行如下命令:

SQL>alter system set deferred_segment_creation=false;

查看:

SQL>show parameter deferred_segment_creation;

该值设置后,只对后面新增的表起作用,对之前建立的空表不起作用,并且注意要重启数据库让参数生效。

2、使用 ALLOCATE EXTEN

使用 ALLOCATE EXTEN可以为数据库对象分配Extent,语法如下:

alter table table_name allocate extent

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

SQL>select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0

批量生成要修改的语句。

然后执行这些修改语句,对所有空表分配空间。

此时用exp命令,可将包括空表在内的所有表导出。

二、利用expdp impdp导出导入

在Oracle10g中exp imp被重新设计为Oracle Data Pump(保留了原有的 exp imp工具)

数据泵与传统导出导入的区别;

1) exp和imp是客户端工具,他们既可以在客户端使用,也可以在服务端使用。

2) expdp和impdp是服务端工具,只能在Oracle服务端使用。

3) imp只适用于exp导出文件,impdp只适用于expdp导出文件。

expdp导出数据:

1、为输出路径建立一个数据库的directory对象。

create or replace directory dumpdir as 'd:\';

可以通过:select from dba_directories;查看。

2、给将要进行数据导出的用户授权访问。

grant read,write on directory dumpdir to test_expdp;

3、将数据导出

expdp test_expdp/test_expdp directory=dumpdir dumpfile=test_expdp_bakdmp logfile=test_expdp_baklog schemas=test_expdp

注意:这句话在cmd窗口中运行,并且最后不要加分号,否则会提示错误。因为这句话是 *** 作系统命令而不是SQL。

impdp导入数据:

1、给将要进行数据导入的用户授权访问。

grant read,write on directory dumpdir to test_impdp;

2、将数据导入

impdp test_impdp/impdp directory=dumpdir dumpfile=test_expdp_bakdmp remap_schema=test_expdp:test_impdp

最后:这些内容是我在查找资料时找到,由于比较杂乱,现在稍作整理,方便以后查阅。同时,如果能给需要的人提供一些帮助,那就再好不过了。

Exp调优

使用DIRECT和RECORDLENGTH选项

DIRECT参数定义了导出是使用直接路径方式(DIRECT=Y) 还是常规路径方式(DIRECT=N) 常规路径导出使用SQL SELECT语句从表中抽取数据 直接路径导出则是将数据直接从磁盘读到PGA再原样写入导出文件 从而避免了SQL命令处理层的数据转换过程 大大提高了导出效率 在数据量大的情况下 直接路径导出的效率优势更为明显 可比常规方法速度提高三倍之多

和DIRECT=Y配合使用的是RECORDLENGTH参数 它定义了Export I/O缓冲的大小 作用类似于常规路径导出使用的BUFFER参数 建议设置RECORDLENGTH参数为最大I/O缓冲 即 ( kb) 其用法如下

      exp userid=system/manager full=y direct=y recordlength= file=exp_full dmp log=exp_full log直接路径导出根据Oracle版本不同 有一些使用限制 比较重要的限制有 i及以下版本不支持导出客户端和数据库的字符集转换 因此导出前必须保证NLS_LANG设置正确; 及以下版本不支持导出含LOBs对象的表;不能使用QUERY参数等

使用管道技术

管道是从一个程序进程向另一个程序进程单向传送信息的技术 通常 管道把一个进程的输出传给另一进程作为输入 如果导出的数据量很大 可以利用管道直接生成最终的压缩文件 所耗费的时间和不压缩直接导出的时间相当 这样一来 不仅能够解决磁盘空间不足的问题 而且省去了单独压缩文件的时间;如果需要传输导出文件 还可以减少网络传输的时间 比如 一个 G的文件单独压缩可能需要半小时以上的时间 虽然管道技术不能够直接缩短Exp/Imp本身的时间 但节省出来的压缩时间非常可观 管道和Exp结合的具体使用方法如下

导出数据示例

     % mknod /tmp/exp_pipe p # Make the pipe

% press < /tmp/exp_pipe > export dmp Z & # Background press

% exp file=/tmp/exp_pipe # Export to the pipe

Imp调优

Oracle Import进程需要花比Export进程数倍的时间将数据导入数据库 某些关键时刻 导入是为了应对数据库的紧急故障恢复 为了减少宕机时间 加快导入速度显得至关重要 没有特效办法加速一个大数据量的导入 但我们可以做一些适当的设定以减少整个导入时间

使用管道技术

前面已经说明了Exp时如何使用管道 在导入时管道的作用是相同 不仅能够解决磁盘空间不足的问题 而且省去了单独解压缩文件的时间 在大数据量导入导出的时候 推荐一定要使用管道

导入数据示例

      % mknod /tmp/imp_pipe p # Make the pipe

% unpress < export dmp Z > /tmp/imp_pipe & # Background unpress

% imp file=/tmp/imp_pipe # Import from the pipe

22 避免I/O竞争

Import是一个I/O密集的 *** 作,避免I/O竞争可以加快导入速度。TwWiNGwIt如果可能,不要在系统高峰的时间导入数据,不要在导入数据时运行job等可能竞争系统资源的 *** 作。

23 增加排序区

Oracle Import进程先导入数据再创建索引,不论INDEXES值设为YES或者NO,主键的索引是一定会创建的。创建索引的时候需要用到排序区,在内存大小不足的时候,使用临时表空间进行磁盘排序,由于磁盘排序效率和内存排序效率相差好几个数量级。增加排序区可以大大提高创建索引的效率,从而加快导入速度。

8i及其以下版本:导入数据前增加数据库的sort_area_size大小,可设为正常值的5-10倍。但这个值设定会影响到所有会话,设的过高有可能导致内存不足出现paging, swapping现象。更为稳妥的方法是,对于大表和索引特别多的表,只导数据不导索引。导完数据后,创建一个会话,设定当前会话的sort_area_size一个足够大的值,再手工创建索引。

9i:在workarea_size_policy=AUTO的情况下,所有会话的UGA共用pga_aggregate_target定义的内存,不必单独设定sort_area_size。导入数据前增加pga_aggregate_target大小,如果机器内存够大,可从通常设定的500M提高到1-2G。pga_aggregate_target大小可以动态调整,导入完成后可在线调回原值。

24 调整BUFFER选项

Imp参数BUFFER定义了每一次读取导出文件的数据量,设的越大,就越减少Import进程读取数据的次数,从而提高导入效率。BUFFER的大小取决于系统应用、数据库规模,通常来说,设为百兆就足够了。其用法如下:

      imp user2/pwd fromuser=user1 touser=user2 file=/tmp/imp_db_pipe1 mit=y feedback=10000 buffer=1024000025 使用MIT=Y选项

MIT=Y表示每个数据缓冲满了之后提交一次,而不是导完一张表提交一次。这样会大大减少对系统回滚段等资源的消耗,对顺利完成导入是有益的。

26 使用INDEXES=N选项

前面谈到增加排序区时,说明Imp进程会先导入数据再创建索引。导入过程中建立用户定义的索引,特别是表上有多个索引或者数据表特别庞大时,需要耗费大量时间。某些情况下,需要以最快的时间导入数据,而索引允许后建,我们就可以使用INDEXES=N 只导入数据不创建索引,从而加快导入速度。

我们可以用INDEXFILE选项生成创建索引的DLL脚本,再手工创建索引。我们也可以用如下的方法导入两次,第一次导入数据,第二次导入索引。其用法如下:

      imp user2/pwd fromuser=user1 touser=user2 file=/tmp/imp_db_pipe1 mit=y feedback=10000 buffer=10240000 ignore=y rows=y indexes=n

imp user2/pwd fromuser=user1 touser=user2 file=/tmp/imp_index_pipe1 mit=y feedback=10000 buffer=10240000 ignore=y rows=n indexes=y

27 增加LARGE_POOL_SIZE

如果在initora中配置了MTS_SERVICE,MTS_DISPATCHERS等参数,tnsnamesora中又没有(SERVER=DEDICATED)的配置,那么数据库就使用了共享服务器模式。在MTS模式下,Exp/Imp *** 作会用到LARGE_POOL,建议调整LARGE_POOL_SIZE到150M。

检查数据库是否在MTS模式下:

SQL>select distinct server from v$session;

lishixinzhi/Article/program/Oracle/201311/18115

简单点使用exp即可。

exp dexter/xiaojun@127001:1521/startrek file=d:\1dmp log=d:\exp1log tables=(dump1)

其中:

1、dexter/xiaojun@127001:1521/startrek

远程数据库的用户名/密码@IP地址:端口号/service_name

2、file

file指定了输出文件的路径

3、log

log为输出log文件的路径

4、tables

指定了要导出的表的名称。(多个表使用逗号分隔,按照用户导出的时候可以去掉tables这个选项)

当你面试的时候突然被问到:MySQL和Oracle的区别?你会怎么回答?其实面试官提问的时候主要是想考察你对数据库的理解以及熟练程度,什么情况下使用 mysql,什么情况下使用 Oracle,各有什么优缺点!下面带大家一起分析这个问题的解答方式!

1 Oracle 是大型数据库而 Mysql 是中小型数据库,Oracle 市 场占有率达 40%,Mysql 只有 20%左右,同时Mysql 是开源的而 Oracle 价格非常高。

2 Oracle 支持大并发,大访问量,是 OLTP 最好的工具。

3 安装所用的空间差别也是很大的,Mysql 安装完后才 152M 而Oracle 有 3G 左右,且使用的时候 Oracle 占用特别大的内存空间和其他机器性能。

4 Mysql *** 作上的区别

①主键Mysql 一般使用自动增长类型,在创建表时只要指定表的主键为 autoincrement,插 入记录时,不需要再指定该记录的主键值,Mysql 将自动增长;Oracle 没有自动 增长类型,主键一般使用的序列,插入记录时将序列号的下一个值付给该字段即 可;只是 ORM 框架是只要是 native 主键生成策略即可。

②单引号的处理MYSQL 里可以用双引号包起字符串,ORACLE 里只可以用单引号包起字符串。在 插入和修改字符串前必须做单引号的替换 、把所有出现的一个单引号替换成两个 单引号。

③翻页的 SQL 语句的处理MYSQL 处理翻页的 SQL 语句比较简单,用 LIMIT 开始位置, 记录个数;ORACLE 处 理翻页的 SQL 语句就比较繁琐了。每个结果集只有一个ROWNUM 字段标明它的 位置, 并且只能用 ROWNUM<100, 不能用 ROWNUM>80。

④ 长字符串的处理长字符串的处理 ORACLE 也有它特殊的地方。INSERT 和 UPDATE 时最大可 *** 作的 字符串长度小于等于 4000 个单字节, 如果要插入更长的字符串, 请考虑字段用 CLOB 类型,方法借用 ORACLE 里自带的DBMS_LOB程序包。插入修改记录前一定 要做进行非空和长度判断,不能为空的字段值和超出长度字段值都应该提出警告, 返 回 上次 *** 作。

⑤空字符的处理MYSQL 的非空字段也有空的内容,ORACLE 里定义了非空字段就不容许有空的内 容。按 MYSQL的 NOT NULL 来定义 ORACLE 表结构, 导数据的时候会产生错误。因 此导数据时要对空字符进行判断,如果为 NULL或空字符,需要把它改成一个空 格的字符串。

⑥字符串的模糊比较MYSQL 里用 字段名 like '%字符串%',ORACLE 里也可以用 字段名 like'%字符串%' 但 这种方法不能使用索引, 速度不快。

⑦Oracle 实现了 ANSII SQL 中大部分功能,如,事务的隔离级别、传播特性等而 Mysql 在这方面还是比较的弱。

MySQL和Oracle都是流行的关系数据库管理系统,在世界各地广泛使用。但是根据他们各自的特性,在使用上有了很大的差别。作为开发者经常要用到数据库,那到底是用MySQL还是用Oracle呢?则需要优先判断企业对于数据库的使用要求而定了。关于MySQL和Oracle的区别你了解了吗?

以上就是关于EXP备份数据库时出现错误提示 EXP-00056: 遇到 ORACLE 错误 29900 同一台机器同一个命令行不知道,求高手全部的内容,包括:EXP备份数据库时出现错误提示 EXP-00056: 遇到 ORACLE 错误 29900 同一台机器同一个命令行不知道,求高手、linux系统中oracle数据库exp命令提示错误怎么解决、如何在oracle中导出,导入数据等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9696898.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存