从达梦数据库到Oracle数据库的性能测试数据迁移和导入优化
为了在同样的数据基础上对比达梦数据库和Oracle数据库的业务性能,我们需要将达梦数据库的数据导入到Oracle数据库中。本文将提供一种思路来解决导入过程中遇到的问题及存在问题记录。
数据库版本信息
- 源数据库:达梦数据库(DM) V8
- 目标数据库:Oracle数据库 V11.2.0.4
导出达梦数据库的数据
首先,将达梦数据库中的数据导出为 .dmp 文件格式。
导入数据到Oracle数据库
在完成达梦数据库的数据导出后,我们将尝试将数据导入到目标Oracle数据库中。然而,直接使用impdp命令导入时出现以下错误:
Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
ORA-39001: invalid argument value
ORA-39000: bad dump file specification
ORA-31619: invalid dump file "/u01/app/oracle/admin/orcl/dpdump/Vxxx_XXX_0816.dmp"
为了解决这个问题,我们可以尝试使用达梦数据库的迁移工具将数据导入到Oracle数据库。然而,根据反馈,有两个表和300多个视图导入失败,导致该数据库也不可用。
为了解决这个问题,我们将采取以下步骤:
1. 在功能测试环境中导出迁移后的Oracle数据库所缺失的视图和表。
- 导出视图:使用
expdp命令导出视图数据。命令示例如下:
expdp $username/$passwd@$ORACLE_SID DIRECTORY=DATA_PUMP_DIR DUMPFILE=$dumpfile.dmp LOGFILE=$dumpfile.log SCHEMAS=$schemas INCLUDE=VIEW
请替换以下参数:
$username:数据库用户名
$passwd:数据库用户密码
$ORACLE_SID:数据库实例名
$dumpfile:导出的文件名(与 $schemas 相同)
$schemas:需要导出的用户名
- 导出多表:使用
exp命令导出多个表的数据。命令示例如下:
exp $username/$passwd@$ORACLE_SID file=/$file_path/$file_name.dmp tables=table1,table2,...
请替换以下参数:
$username:数据库用户名
$passwd:数据库用户密码
$ORACLE_SID:数据库实例名
$file_path:导出文件的路径
$file_name:导出文件名称
tables=table1,table2,...:要导出的表名列表,以逗号分隔
2. 将导出的视图和表数据导入到迁移后的Oracle数据库中。
- 导入视图:使用
impdp命令导入视图数据。命令示例如下:
impdp $username/$passwd@$ORACLE_SID DIRECTORY=DATA_PUMP_DIR DUMPFILE=$dumpfile.dmp LOGFILE=$dumpfile.log REMAP_SCHEMA=$fromUser:$toUser
请替换以下参数:
$username:数据库用户名
$passwd:数据库用户密码
$ORACLE_SID:数据库实例名
$dumpfile:导入的文件名
$fromUser:导出数据库用户名
$toUser:导入数据库用户名
- 导入多表:使用
imp命令导入多个表的数据。命令示例如下:
imp $username/$passwd file=/$file_path/$file_name.dmp log=/$log_path/$log_name.log fromuser=$fromuser
请替换以下参数:
$username:数据库用户名
$passwd:数据库用户密码
$file_path:导入文件的路径
$file_name:导入文件名称
$log_path:导入日志的路径
$log_name:导入日志名称
$fromuser:导出数据库用户名
通过以上步骤,将导入失败的视图和表从功能测试环境中导出,并将其导入到迁移后的Oracle数据库中。
但是,启动应用服务,仍存在缺失相关视图或语法方面的报错。尝试先将导出的视图和表导入新建的数据库用户,再导入从达梦服务导出的数据库,缺失相关视图或语法方面的问题仍然存在。
根据Oracle数据可以成功导入达梦,而达梦导入Oracle却存在报错。足以说明:达梦做到去兼容Oracle,但Oracle却没去兼容达梦。
考虑到再继续付出时间、精力去研究导入数据库启动服务失败的问题,不一定能够解决该问题,且产出比较低。只好在达梦数据库重造性能测试数据。
总结
本文介绍了在对比达梦数据库和Oracle数据库的业务性能时,如何将达梦数据库的数据导入到Oracle数据库中。我们通过导出.dmp文件并利用达梦数据库的迁移工具,进行数据库的导入。但由于Oracle未对达梦进行兼容适配,导致最终的结果还是失败。
从达梦数据库到Oracle数据库的性能测试数据迁移和导入优化的更多相关文章
- mysql数据库及oracle数据库的定时备份
一.oracle数据库备份bat文件 @echo off md "%date:~0,10%" cd "%date:~0,10%" echo exp 用户名/密码 ...
- sybase数据库和oracle数据库中字段中含有换行符的解决办法
最近在做数据库从sybase到oracle的迁移工作,sybase数据库表bcp导出后,通过sqlldr导入到oracle数据库,然后oracle数据库通过spool按照sybase数据库bcp的格式 ...
- 用EF的三种方式(SqlServer数据库和Oracle数据库)
SqlServer数据库 1.DB First 现有DB,生成edmx文件 贴一下生成的model //------------------------------------------------ ...
- 初识 数据库及Oracle数据库
一.数据库基本概念二.数据库举例三.Oracle特点四.Oracle版本五.安装Oracle注意事项六.SQL简介七.Select语句 一.数据库基本概念 数据库(Database,DB)数据库管理系 ...
- mysql数据库和oracle数据库之间互相导入备份
把从Oracle数据库导出的数据导入到MySql数据库中1. 使用默认的结束符号导入到MySql数据库中: LOAD DATA LOCAL INFILE 'd:/oracle.txt' IGNO ...
- Java连接MySQL数据库和Oracle数据库并进行简单的SQL操作的一次尝试
MySQL和Oracle的JDBC的maven dependency如下: <!-- mysql --> <dependency> <groupId>mysql&l ...
- 转:ACCESS数据库转ORACLE数据库分享
来源: 作者:zz 网上有很多文章介绍access转oracle数据库的方法,本人都尝试了,不是很成功,列举一下,后来人不必盲目试了,基本不成功: 1.Access-->excel-->P ...
- servlet连接mysql数据库和oracle数据库
连接mysql数据库 package dao; import java.sql.Connection; import java.sql.DriverManager; import java.sql.P ...
- MySQL数据库和Oracle数据库的区别
Mysql数据库 由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司.是一种中小型的关系型数据库. MySQL 数据库体积小.速度快.总体拥有成本低.开放源代码,其有着广泛的应用,一般中 ...
- mysql数据库与oracle数据库的切换
1.从mysql数据库中导出ambition(数据库名)结构和数据的ambition.sql文件. 2.将ambition.sql用Power Designer转换成mysql数据模型. 给模型起个名 ...
随机推荐
- Vulnhub Broken
Vulnhub Broken 一.操作文档 [Vulnhub - Broken-Gallery writeup (mzfr.me)](https://blog.mzfr.me/vulnhub-writ ...
- MySQL-DQL
准备测试表,先跟着执行下面的SQL #1.登录MySQL后 #2.创建test_database数据库,不存在则创建 create database if not exists test_databa ...
- python 环境下使用PIP 报错的解决方法
最近做一个小程序项目,使用djangorestframework,安装restframework 出现错误,安装环境Python2.7:出现错误如下: "UnicodeEncodeErro ...
- 读少写多的条件下 ConcurrentHashMap 和 ReadWriteLock 的选择
场景是这样的:两个对象往一个 Map 里循环写入,另外一个对象偶尔读一次,写的频率比读的频率高很多.希望实现的是读的时候暂停写入.CocurrentHashMap 和 ReadWriteLock 各有 ...
- 02-面试必会-SSM框架篇
01-什么是 Spring IOC 和 DI ? IOC : 控制翻转 , 它把传统上由程序代码直接操控的对象的调用权交给容 器,通过容器来实现对象组件的装配和管理.所谓的"控制反转&quo ...
- ASIC加速技术在ASIC加速性能优化中的新应用与挑战
目录 1. 引言 2. 技术原理及概念 3. 实现步骤与流程 4. 应用示例与代码实现讲解 5. 优化与改进 1. 引言 随着计算机技术的发展,芯片的性能和面积都得到了极大的提升.为了进一步提高芯片的 ...
- Kali-Shell简单介绍&Vim编辑器指令
Shell简单介绍 shell :外壳(用户与操作系统(内核)之间的桥梁)相当于Windows中的dos 1.查看shell cat /etc/shells 查看系统支持哪些Shell echo $s ...
- Centos使用keepalived配置MySQL双主热备集群
目录 安装MySQL 下载安装包 卸载mariadb-lib 安装依赖 安装gcc 安装perl 永久关闭selinux 安装 配置 创建mysql数据库管理用户和组 创建数据目录 修改my.cnf配 ...
- 现代C++(Modern C++)基本用法实践:零、概述&测试项目
序言 习惯上,我们把C++11之前的C++语法特性称之为"传统C++(traditional c++)",而把c++11之后的语法特性称之为现代C++(modern c++).有一 ...
- Typora markdown 满屏显示,去除两边的留白
Typora 宽度在CSS样式文件中有个 max-width 值,现在的显示器分辨率比较高,会导致编辑器两边留白比较多 导致文档编辑时,高分辨率的显示器,得不到充分利用 解决方案 修改源码编辑器样式 ...