您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

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

2024/4/26 4:06:15发布30次查看
oracle exp/imp是早期推出数据备份还原工具。因其简单易用、功能强大的特性,广泛的被行业接受。一些开发工具(如pl/sql develop
oracle exp/imp是早期推出数据备份还原工具。因其简单易用、功能强大的特性,广泛的被行业接受。一些开发工具(如pl/sql developer)中甚至集成嵌入了exp/imp工具。一些国内开发团队默认数据部署策略中,exp/imp也占到了相当比例。
随着oracle版本的推进,新特性的推出,特别是海量数据库不断出现在企业应用环境下,传统的exp/imp工具架构已经不能承担发展的需要。于是在10g版本中,oracle推出了服务端运行的数据泵data pump工具。到11g版本中,data pump已经成为成熟的数据导入导出、备份解决方案。
但是在实际开发领域,exp/imp还是有很大的市场。虽然11g中已经不推荐使用exp/imp,但是很多厂商部署小数据应用还是采用exp/imp方法。
本次记录的是一次部署导出exp中出现的问题,记录下来,留待需要的朋友需要。
--------------------------------------分割线 --------------------------------------
oracle 11g 在redhat linux 5.8_x64平台的安装手册
linux-6-64下安装oracle 12c笔记
在centos 6.4下安装oracle 11gr2(x64)
oracle 11gr2 在vmware虚拟机中安装步骤
debian 下 安装 oracle 11g xe r2
--------------------------------------分割线 --------------------------------------
1、问题综述
厂商上线部署系统,进行最后的数据导出导入测试。由于不是最终的环境,而且上线系统数据量初始比较少,所以推荐使用exp/imp或者data pump工具。在导出过程中,系统数据虽然成功导出,但是出现报错exp-00091。对应截屏照片如下(安全原因,屏蔽部分信息):
导出语法也没有什么额外的信息过程。一时间笔者也没有处理的思路。
2、问题分析和检索
留下错误信息提示和语句信息之后,笔者查询了oracle mos官方网站,希望找到对应的资料。在文档exp utility reports exp-91 during export (文档 id 730106.1)中,笔者找到了这个问题的解释。
oracle统计量是cbo的工作基础。oracle优化器在发展历程中,经历了从rbo到cbo的演变过程。rbo时代,优化器生成规则是以代码的方式固化在oracle代码中的。而cbo的工作是基于数据对象统计量。统计量反映在实体上,就是一系列的元数据信息。在9i时代,cbo与rbo共同作用,而且统计量是需要人工进行收集维护的。而且,由于数据变化的原因,在一些早期cbo版本中,“实时”统计量往往还不能获得最好的执行计划。
所以,在9i的exp/imp工具开始,统计量导出就成为exp工具默认行为。exp/imp工具是一个客户端工具,客户端的字符集设置nls_lang和数据库服务器端是存在不同的。如果nls_lang环境变量设置与数据库服务器设置不同,就会导致这个问题出现。
下面我们通过实验来试图重现错误,来证实我们的推论。
3、错误模拟
我们使用oracle 11gr2来进行测试模拟,具体版本号为11.2.0.4。客户端操作系统为windows。
sql> select * from v$version;
banner
--------------------------------------------------------------------------------
oracle database 11g enterprise edition release 11.2.0.4.0 - 64bit production
pl/sql release 11.2.0.4.0 - production
core      11.2.0.4.0    production
tns for 64-bit windows: version 11.2.0.4.0 - production
nlsrtl version 11.2.0.4.0 – production
当前,服务器nls关键参数如下。注意,查看nls信息一定是数据库层面的。
sql> select * from nls_database_parameters;
parameter                      value
------------------------------ --------------------------------------------------------------------------------
nls_language                  american
nls_territory                  america
nls_currency                  $
nls_iso_currency              america
nls_numeric_characters        .,
nls_characterset              al32utf8
(篇幅原因,有省略……)
nls_lang环境变量的参数格式包括nls_language、nls_territory和nls_characterset。具体格式如下:
nls_lang=_.
更多详情见请继续阅读下一页的精彩内容:

该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product