db2迁移至oracle

1.思路

(1)用java连接数据库(2)把DB2数据导出为通用的格式如csv,json等(3)导入其他数据库,比如oracle,mongodb。这个方法自由发挥的空间比较大。朋友说他会用springboot自带的包来导,我没有进行测试。

(2)根据oracle的官方指导,使用sql server进行迁移

db2迁入oracle,网站官方有详细步骤,或者可以参考另一篇中文文章

Connect Step DB2

如何将DB2数据库转换成Oracle数据库,这一篇告诉你-腾讯云开发者社区-腾讯云

2.注意事项

(1)sql server 需要安装db2jcc4.jar或db2jcc.jar才能连接db2库,下载地址ibm官网有提供,请根据自己的db2选择合适的版本,注意下载下来后是个tar.gz格式,需要解压,win系 统用户可采用7.zip软件进行两次解压

DB2 JDBC Driver Versions and Downloads

(2)db2与oracle存在一定的数据格式差异。如果采用了第一种思路,并且不准备采用任何第三方工具或者包,要自己手动导的话一定要注意。

3.测试案例

db2版本:10.0.5

sql developer版本 22.2.1

参考的oracle官方教程,也适用于其他数据库迁移到oracle

step 1:Set up a Migration Repository

这一步我省略了,因为我这里只有dba有权限,就直接联系dba开了测试库并在sql developer中建立了连接。

建议还是新开一个schema作为目标库。

源库也建议备个份

 

step2:Configuring the Third Party Database Connection

(1)sql developer导入db2jcc4.jar和db2jcc.jar包

(2)创建和db2库连接

step 3:Capturing Source Database

(1)右键点击要迁移的库,选择迁移到oracle,这一步会打开迁移向导工具

(2)选择迁移的目标库

(3)选择源库,官方建议数据量大选 脱机

(4)捕获,选择你要迁的数据库

step4 :Convert Captured Model to Oracle

这一步完成db2到oracle的数据类型映射,你可以在迁移向导里面手动调整,或者新建映射

step5:Translate Third Party SQL Objects to Oracle

这一步会将源库的 约束、函数、存储过程、触发器、视图 翻译成Oracle SQL对象,可以只选择一部分。

在这里可以先点击完成会自动操作,转化完成后你可以到报告栏查看再回到迁移向导。官方视频里有。

step6:Generating Scripts to Create Target Database

这被用来生成用于创建新的Oracle数据库模式的SQL脚本,并运行这些脚本。如果你选择脱机模式的话,脚本会保存在本地。下面有一个删除目标对象的选项,我感觉可能是清库,没测。 

step7:Move Data from Third Party Database to Oracle

迁移向导的最后一步是将数据迁移到新的数据库中。在线模式的话需要指定好源库和目标库,脱机模式不用。下面有一个截断数据(truncate data)的选项,我感觉也可能是清库,没测。

参考

操作

Connect Step DB2

如何将DB2数据库转换成Oracle数据库,这一篇告诉你-腾讯云开发者社区-腾讯云

jar包

DB2 JDBC Driver Versions and Downloads

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/58617.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何在PyQt应用程序中使用Qt Designer和Pyuic工具?

如果你想在PyQt应用程序中使用Qt Designer和Pyuic工具,那么首先你需要确保你已经安装了这些工具。你可以通过以下命令在你的Python环境中安装它们: pip install pyqt5 pip install pyqt5-tools安装完成后,你就可以开始使用Qt Designer设计…

BananaPi BPI-6202工业控制板全志科技A40i、24V DC输入、RS485接口

Banana Pi BPI-6202“嵌入式单板计算机”采用工业级全志A40i四核Cortex-A7处理器,工业温度范围和长生命周期,2GB DDR3,8GB eMMC闪存,M.2 SATA插槽等。 这是自 Banana Pi去年推出Banana Pi BPI-M2 Ultra SBC 和BPI-M2 Berry以来&am…

彻底搞懂 PHP 运算符 ?: 和 ??

文章目录 快速掌握?: 短三元运算符?? NULL 合并运算符 附上官方文档查阅方式 快速掌握 ?: 短三元运算符 ?: 称之为短三元运算符,它是我们熟悉的三元运算符(也叫做条件运算符)的一种特殊写法,也就是省略了三元运算符中间的部…

算法通关村第8关【黄金】| 寻找祖先问题

思路:递归三部曲 第一步:确定参数和返回值 题目要求找到指定的结点,就需要返回结点。 题目又涉及到p,q就需要传入p,q,需要遍历传入root 第二步:确定终止条件 当遍历到结点为空说明到底没找到返回空 或者遍历到p,…

华为云新生代开发者招募

开发者您好,我们是华为2012UCD的研究团队 为了解年轻开发者的开发现状和趋势 正在邀请各位先锋开发者,与我们进行2小时的线上交流(江浙沪附近可线下交流) 聊聊您日常开发工作中的产品使用需求 成功参与访谈者将获得至少300元京…

Xshell7和Xftp7的下载、安装及连接服务器的教程

1.下载 1.官网地址: XSHELL - NetSarang Website 选择学校免费版下载 2.将XSHELL和XFTP全都下载下来 2.安装 安装过程就是选择默认选项,然后无脑下一步 3.连接服务器 1.打开Xshell7,然后新建会话 2.填写相关信息 出现Connection establ…

【算法】双指针求解盛最多水的容器

Problem: 11. 盛最多水的容器 文章目录 题目解析算法原理讲解复杂度Code 题目解析 首先我们来解析一下本题 题目中说到,要找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。 那我们现在来看最外侧的两根,一个高度为8&#…

Databend 开源周报第 108 期

Databend 是一款现代云数仓。专为弹性和高效设计,为您的大规模分析需求保驾护航。自由且开源。即刻体验云服务:https://app.databend.cn 。 Whats On In Databend 探索 Databend 本周新进展,遇到更贴近你心意的 Databend 。 多源数据目录 …

LA@向量运算@内积@向量正交

文章目录 内积符号说明向量内积性质对称性线性性正定性 推论:柯西-布尼亚科夫斯基-施瓦茨公式(柯西不等式)解系几何向量的数量积和线性代数向量内积n维向量的长度(范数)向量长度的性质单位向量单位化 向量夹角 向量正交标准正交正交向量组正交向量组线性无关记号补充Note例 标准…

无涯教程-Android - Intents/Filters

Android Intent 是要执行的操作的抽象描述。它可以与 startActivity 一起启动Activity,将 broadcastIntent 发送给任何BroadcastReceiver组件,并与 startService(Intent)或 bindService(Intent,ServiceConnection,int)与后台服务进…

线程的几种状态

在多线程编程中,线程可以处于不同的状态,表示它们的执行状态和行为。以下是 Java 中线程的几种常见状态: NEW(新建状态) 线程被创建但尚未启动 在这个状态下,线程对象已经被创建,但还没有调用 start () 方法来启动线程的执行。线程对象可以是通过实例化 Thread 类创建…

如何优雅地创建一个自定义的Spring Boot Starter

优雅永不过时,希望看完本文,你会觉得starter如此优雅! Spring Boot Starter是一种简化Spring Boot应用开发的机制,它可以通过引入一些预定义的依赖和配置,让我们快速地集成某些功能模块,而无需繁琐地编写代…

用PM2和xltpl开发一个Excel模板导出FLASK API

作为码农最不会陌生的就是数据导出,最常见的就是Excel和Word。一般来说没啥,用个Office相关组件,写写格式和数据绑定都ok了,但是就怕管理层各种标准格式模板,你也不知道为什么用电脑 Analysis 几分钟的事(p…

vue + electron

node 版本 v14.19.3 npm 版本 6.14.17 要是node-sass报错执行命令: npm uninstall node-sass sass-loader npm i node-sass4.14.1 sass-loader7.3.1 --save -dev首先安装依赖 npm install electron npm install electron-packagerelectronRun.js放在根目录下 con…

华硕笔记本摄像头倒置怎么办?华硕笔记本摄像头上下颠倒怎么调整

笔记本电脑相较于台式电脑,更易携带,解决了很大一部分人的使用需求。但是笔记本电脑也存在很多不足,比如华硕笔记本电脑就经常会出现摄像头倒置的错误,出现这种问题要如何修复呢?下面就来看看详细的调整方法。 华硕笔记…

第十八掌、【Linux】认识与分析登录文件

18.1 什么是登录文件 什么是登录文件?简单地说,就是记录系统活动信息的几个文件,例如:何时何地何人,做了什么工作。换句话说就是:记录系统在什么时候由哪个程序做了什么样的行为时,发生了什么事…

centos安装Nginx配置Nginx

1. 查看操作系统有没有安装Nginx which nginx 2. 使用epel的方式进行安装(方法二) 先安装epel sudo yum install yum-utils 安装完成后,查看安装的epel包即可 sudo yum install epel 3 开始安装nginx 上面的两个方法不管选择哪个&…

万能近似定理(Universal Approximation Theorem)

万能近似定理(Universal Approximation Theorem)是指一个神经网络可以以任意精度来近似任何连续函数。这个定理最早由George Cybenko于1989年首次提出,并且后来由Kurt Hornik在1991年进行了进一步的证明。 具体来说,万能近似定理表…

MySQL官网下载安装包

MySQL官网: MySQL MySQL 8.0官网下载地址: MySQL :: Download MySQL Community Server 2023-07-18 MySQL 8.1.0 发布,这是 MySQL 变更发版模型后的第一个创新版本 (Innovation Release) 。 如果在官网中找不到下载位置,点击第二个…

JS获取Beego渲染模板Temple时传递的数据

如果纯粹的JS调用接口,获取后端数据很直接坦率,JSON解析也就可以了。 如果需要JS获取HTML页面加载时,后端传回来的一些数据,我们也可以通过以下的方式进行获取。范例如下: //通过person_name字段传递参数到html页面中…