手机公司网站建设,wordpress前端上传图片,正规微商免费推广软件,门户网站规划方案用Oracle导入导出工具实现Oracle数据库移植.很不错的方法,建议使用![more]用Oracle导入导出工具实现Oracle数据库移植Oracle数据库作为目前市场的主流数据库之一#xff0c;许多应用都在其上进行开发#xff0c;由于Oracle数据库更新换代的原因和不同的应用程序提供商#x…用Oracle导入导出工具实现Oracle数据库移植.很不错的方法,建议使用![more]用Oracle导入导出工具实现Oracle数据库移植Oracle数据库作为目前市场的主流数据库之一许多应用都在其上进行开发由于Oracle数据库更新换代的原因和不同的应用程序提供商可能会造成在一个单位的应用中存在Oracle的几种版本如Oracle 7、Oracle 8、Oracle 8i甚至Oracle 9i.。而考虑到数据库集中、维护、备份的方便性和避免设备的重复投资在应用能兼容的情况下将几个版本的Oracle数据库移植到一个主流版本上是数据库管理员的一个较优的选择。这就存在从Oracle数据库的低版本移植到高版本和从Oracle数据库的高版本移植到低版本的问题甚至包括系统平台的迁移如从Windows NT系统迁移到Unix系统。利用Oracle导入/导出工具(Export/Import)能比较方便实现上述移植操作。Oracle导入/导出工具(Export/Import)主要是用来对数据库进行逻辑备份利用Export导出数据库的转储二进制文件作为数据库Import输入从而达到移植的目的。有二个规则可以参考规则一从Oracle 低版本的Export数据可以Import到Oracle高版本中但限于Oracle的相邻版本如从Oracle 7 到 Oracle 8。对于两个不相邻版本间进行转换如从Oracle 6 到 Oracle 8则应先将数据输入到中间版本—Oracle 7再从中间数据库转入更高版本。规则二Oracle的Export/Import工具只能连接到拥有更高或者一样的Export/Import版本的数据库。如Oracle 8.0.5的Export/Import(版本8.0.5.0.0)可连接到Oracle 8.1.6数据库(版本8.1.6.0.0)高版本的Export导出来的转储文件低版本的Import读不了低版本的Export导出来的转储文件高版本的Import可以进行读取。利用上面两个规则下面就本人在为一单位用Oracle的导入/导出工具(Export/Import)进行此种移植碰到的问题提出来与大家分享希望能起到抛砖引玉的作用。此单位拥有Oracle数据库版本有Oracle 8.1.6 For NT、Oracle 8.0.5 For NT、Oracle 8.0.4 For Digital Unix、Oracle 7.3 For NT。考虑到Oracle 8.0.4 For Digital Unix运行在小型机上、单位的备份系统也是针对此小型机决定将Oracle 8.1.6 For NT、Oracle 8.0.5 For NT、Oracle 7.3 For NT的数据库都移植到Oracle 8.0.4 For Digital Unix上。1、Oracle 8.0.5 For NT移植因版本相差甚小开始直接用Oracle8.0.5的exp80导出数据库的转储文件然后用FTP(binary传输模式)直接上传至Oracle 8.0.4 所在的小型机再用Oracle 8.0.4的imp导入一直有字符集的问题即存有汉字的字段显示的都是”??????” 移植失败。后发现在Oracle8.0.5服务器上直接用Oracle8.0.5的imp80对exp80导出的转储文件进行远程导入字符集的问题解决移植成功。对于使用Oracle 8.0.4 For Digital Unix的用户提醒一句最好不要用Oracle 8.0.4 For Digital Unix的exp、imp工具做备份而应用此版本的Windows客户端程序exp80、imp80。本人曾做过实验在Oracle 8.0.4 for Digital UNIN数据库上新建一用户(user)和一个表格(table)通过sql plus客户端在表格的列中插入一些中文行提交后用exp 数据导出再用imp数据导入用sql plus客户端查看表中的中文值显示为”???”)。2、Oracle 7.3 移植直接用Oracle7.3的export导出数据库的转储文件拷至Oracle8.0.5服务器然后用Oracle8.0.5服务器的imp80直接导入至Oracle 8.0.5数据库。此移植就变成了Oracle 8.0.5 For NT移植至Oracle 8.0.4 For Digital Unix的移植。3、Oracle 8.1.6 For NT移植初步设想也通过Oracle 8.0.5进行过度。因其版本比Oracle 8.0.5高、下面对参考的规则进行一些校验。31高版本的Export导出来的转储文件低版本的Import读不了在Oracle 8.1.6数据库服务器导出转储二进制文件ora816.dmp。在Oracle 8.0.5数据库服务器上用Imp80进行导入。D:Imp80 house/password filed: ora816.dmp logd:ora816.log fully/*日志显示*/已连接到Oracle8 Release 8.0.5.0.0 – ProductionPL/SQL Release 8.0.5.0.0 – ProductionIMP-00010: 不是有效的导出文件标题检验失败IMP-00021: 操作系统错误 - 错误代码(十进制2十六进制0x2)IMP-00000: 未成功终止导入32 Oracle的Export/Import工具只能连接到拥有更高或者一样的Export/Import版本的数据库a)Oracle 8.1.6远程数据导入在Oracle 8.1.6数据库服务器导出转储二进制文件ora816.dmp。在Oracle 8.1.6数据库服务器向Oracle8.0.5数据库进行数据远程导入D:Imp filed: ora816.dmp logd:ora816.log fully(orclfrom816to805为数据库连接字符串由Oracle8.1.6数据库指向 Oracle8.0.5数据库)/*日志显示*/连接到: Oracle8 Release 8.0.5.0.0 – ProductionPL/SQL Release 8.0.5.0.0 – Production……经由常规路径导出由EXPORT:V08.01.06创建的文件已经完成ZHS16GBK字符集和ZHS16GBK NCHAR 字符集中的导入IMP-00003: ORACLE 错误2248出现ORA-02248: 无效的 ALTER SESSION 选项IMP-00000: 未成功终止导入b)在Oracle 8.0.5数据库服务器上用exp80对Oracle 8.1.6数据库进行远程导出。D:exp80 filed:ora816.dmp logd:ora816.log(orclfromfrom805to816为数据库连接字符串由Oracle8.0.5数据库指向Oracle8.1.6数据库)/*日志显示*/连接到Oracle8i Enterprise Edition Release 8.1.6.0.0 – ProductionWith the Partitioning optionJServer Release 8.1.6.0.0 – Production已导出ZHS16GBK字符集和ZHS16GBK NCHAR 字符集即将导出指定的用户...……在没有警告的情况下成功终止导出。再对远程导出的转储文件在Oracle 8.0.5数据库服务器上用imp80导入。D:imp80 house/password filed:ora816.dmp fully logd:ora816 _i.log显示成功导入此刻此移植就变成了Oracle 8.0.5 For NT移植至Oracle 8.0.4 For Digital Unix的移植。利用Oracle的Oracle导入/导出工具(Export/Import)除了可进行数据库逻辑备份、数据库移植还可以用来提高数据库的性能对数据库进行一次导入/导出操作能重新组织数据消除数据库的碎片从而使数据库的性能有较大的提高。