Oracle数据库移植到KingbaseES的全流程

 更新时间:2025年09月30日 08:38:12   作者:鸽芷咕  
在国产化替代浪潮下,将Oracle数据库迁移至KingbaseES(金仓数据库)已成为众多企业的选择 ,KingbaseES作为Oracle兼容版数据库,通过原生支持大量Oracle特性,大幅降低了迁移难度,下面我们就来从Oracle到KingbaseES的完整迁移流程,需要的朋友可以参考下

前言

在国产化替代浪潮下,将Oracle数据库迁移至KingbaseES(金仓数据库)已成为众多企业的选择 。 KingbaseES作为Oracle兼容版数据库,通过原生支持大量Oracle特性,大幅降低了迁移难度。下面我们就来从Oracle到KingbaseES的完整迁移流程,给各位带来一份从前期准备到落地验证的实战指南,助力企业实现平滑、高效的数据库国产化升级。

一、迁移前必知:为什么选择KingbaseES?

在启动迁移前,首先要明确KingbaseES的Oracle兼容优势——这是降低迁移成本的核心前提。根据官方文档,KingbaseES在关键层面实现了高度兼容:

  • 数据类型全覆盖:原生支持Oracle的NUMBER、VARCHAR2、DATE、ROWID等基础类型,以及RECORD、%TYPE、关联数组等复杂PL/SQL类型,无需修改数据结构定义。
  • SQL与PL/SQL兼容:支持TRUNCATE、层次查询、闪回查询、MERGE等Oracle特有SQL语句,同时兼容IF-THEN-ELSE、FORALL、自治事务等PL/SQL语法,甚至支持DBMS_SQL、DBMS_LOB等常用内置包。
  • 工具链适配:提供KSQL(类似SQL*PLUS)、KStudio(类似SQL Developer)等客户端工具,迁移过程中无需改变运维习惯。

简单来说,大部分Oracle应用只需“少量修改甚至零修改”,即可在KingbaseES上运行——这是选择它的核心原因。

二、 迁移前准备

Oracle到KingbaseES的迁移并非“直接拷贝数据”,而是遵循“准备-迁移-测试”的标准化流程。

2.1 获取 Oracle 数据库的相关信息

迁移前,应获取源数据库Oracle 服务名及迁移的数据规模信息。其中,前者用于 PL/SQL Developer 工具的登录操作,后者用于估算数据迁移时间和设计迁移方案。

  1. Oracle 数据库基本信息
    获取源Oracle 数据库的:
    a. IP 地址;
    b. 实例名;
    c. 网络服务端口号;
    d. 用户名/密码。
  • 在目标KingbaseES 上:
    a. 创建与源Oracle 用户(如 scott)同名的用户(scott);
    b. 创建与源Oracle(如 ORCL)同名的数据库(ORCL),属主为scott;
    c. 创建与源Oracle(与用户名相同 t)同名的模式scott,属主为 scott。

2.2 查询Oracle 数据库编码方式

select userenv('language') from dual;
 USERENV('LANGUAGE')
 SIMPLIFIED CHINESE_CHINA.ZHS16GBK
【KingbaseES初始化设置编码方式】
--encoding=GBK(支持GBKUNICODEASCII)

2.3 看表数据量大小

查看当前用户在Oracle中的表大小,按从大到小排序(单位GB)

select segment_name,bytes/1024/1024/1024 fromuser_segmentswheresegment_type='TABLE'order by
 bytesdesc ;
 XFJXX16.046875
 XFRXX7.779296875
 PCK 7.4375
 BLFSXX 5.0625
 XFSXXX 2.3125
 DFGZXX 1.3359375
 FJB 0.53125
 TSJXX0.078125

2.4 检查数据库日期格式

时间的默认格式为:ISO,MDY

在配置文件中添加:datestyle=’ISO,YMD’修改为年月日的格式(99会改为1999)

在某项目中迁移数据时遇到:服务器报错,迁移工具中断,迁移停滞

  • oracle数据库中有日期“0099-09-3000:00:00”,迁移工具输出为“99-09-3000:00:00”,KingbaseES中将99识别为月份报错:ERROR:date/timefieldvalueoutofrang
--即使没有报错也会出现错误
set ora_date_sytle=true;
 CREATE TABLET_DATE(COLDATE);
 INSERT INTO T_DATEVALUES('11-10-1010:10:10');
 SELECT *FROMT_DATE;
 COL--------------------
2010-11-1010:10:10
 (1 row)

三、配置 KingbaseES 的 Oracle 兼容开关

在 Oracle 数据库向 KingbaseES 迁移的过程中,为确保两者在功能和数据存储上的兼容性,需根据实际场景对 KingbaseES 目的数据库进行 Oracle 兼容配置。以下将针对需重点配置的会话级兼容参数展开说明,明确各参数的作用、配置依据及注意事项。

3.1 nls_length_semantics 参数

该参数的核心作用是设定char类型字段的默认单位(byte或char),同时标识符的最大长度也会以该参数值为单位 —— 若参数值为char,标识符最大长度为 63 个char;若为byte,则最大长度为 63 个byte。

从配置依据来看,KingbaseES 中nls_length_semantics参数的默认值为CHAR,但迁移时需确保其与待迁移的 Oracle 数据库参数值保持一致。Oracle 数据库中,char类型的byte/char属性默认值由NLS_LENGTH_SEMANTICS参数决定,可通过如下 SQL 语句查询该参数值:

select value from nls_database_parameters where parameter = 'NLS_LENGTH_SEMANTICS';

如果未修改可能会出现:迁移 char 类型时,由于数据库存储的类型不同,导致迁移的数据存在多余空格的情况。

3.2 default_with_oids:OID 伪列开关

KingbaseES 的 OID 伪列可兼容 Oracle 的 ROWID 伪列。因此,如果Oracle 移植对象有 ROWID 伪列,则建议用OID伪列替代。

四、KDTS数据的离线迁移实战

在完成上述准备工作以后,我们就可以使用KDTS进行数据的离线迁移了,KDTS提供了两种形态(BS、SHELL),可以根据需要进行选择,我们在这里就给大家介绍BS的oracle迁移的具体步骤。

4.1 创建源数据库连接

创建源库数据库连接。创建数据库连接界面如下,填写数据源信息,包括:“连接名称”、“数据库
类型”、“数据库版本”、“服务器地址”、“端口”、“用户名”、“密码”、“数据库”、“连接参
数”。

4.2 创建目标数据库连接

创建目标数据库连接。创建数据库连接界面如下,填写数据源信息,包括:“连接名称”、“数据
库类型”、“数据库版本”、“服务器地址”、“端口”、“用户名”、“密码”、“数据库”、“驱
动”、“URL”、“连接参数”。

4.3 新建迁移任务

KDTS 采用向导页的方式指导用户新建迁移任务,简单易用,用户依次配置“选择数据源”-“选择模
式”-“选择迁移对象”-“配置参数”,即可快速配置一个迁移任务。

  • 选择数据源

填写自定义任务名称(任务名称不能重复),选择“源数据库”和“目标数据库”,或者选择“新建数据源”后使用

4.4 选择模式

根据我们的数据迁移所需选择对应模式(如需选择模式在系统模式中可选中“包含系统模式”复选
框)的表、视图、序列、函数、存储过程、程序包、同义词。当模式较多时也可以通过左上方的查
询框进行检索。请您至少选择一种模式,否则将收到错误提示,以至于不能完成新建任务。

4.5 选择迁移对象

通过已选模式选择我们需要迁移数据的表,模式较多时可在已选模式搜索框内输入模式名关键字进行快速检索。

可迁移此模式下全部表,也可以指定或排除部份表,当你选择“包含指定表”或“排除指定表”
时,请通过“从列表选择”、“从文件导入”或者在输入框内输入表名将数据添加到包含列表
中,如未添加数据,则会提示错误导致无法进行下一步并完成新建任务。

当我们点击“包含指定表”时也可选择多种方式。可直接在输入框内填写表名,多个表用“,”分割,回车确认;“从列表选择”可在模式中选择指定表;如您要“从文件导入”,可点击“下载导入模板”,根据导入模板规则填写,然后从文件导入该模板。当您需要“排除指定表”时,同指定部份表相同操作,但结果相反。

从列表选择表时,可选择对应模式、检索表名关键字、数据条数限制进行快速检索对应的表。点击
“添加”按钮后加入到已选列表,当您想要移除部份表时可以选择对应的表点击“移除”按钮取消
表。选择完成后点击确定。

4.6 配置参数

迁移工具给我们提供了一系列配置参数用于迁移方案的个性化配置,满足多种迁移场景。配置参数分为“迁移配置”、“数据类型映射”、“线程配置”三个方面。

  • 表默认处理方式
    包含“建表/重建表”“导入数据”两个复选框选项,用于选择迁移到KingBaseES数据库时,是否需要建表或重建表,以及是否仅迁移表结构而不迁移数据。默认是全选。
  • 表排序依据
    可对迁移的表进行排序,排序方式有“按行数和大字段大小交替”“行数”“大小”,默认是按行数和大字段大小交替。
  • 表数据读取和写入
    能为表数据的读取和写入制定规则,可操作的选项有“源库游标读取记录数”(默认是100)、“批量写入目标库记录数”(默认是1000)、“每次批量提交大小”(默认是100MB)、“LOB字段预读取大小”(默认是4000Byte)。
  • 大表拆分阈值依据
    用于对大表进行拆分迁移,可设置拆分的界限。
  • 非对象设置
    其中有“主键”“检查约束”“唯一约束”“外键”“索引”“触发器”“自动转换对象名”等选项,可根据需求选择是否迁移这些非对象数据,默认是全选。
  • 数据库连接数设置
    可以限制迁移程序对源数据库和目标数据库的最大连接数,默认是100。
  • 执行迁移任务
    可将此任务作为预迁移任务点击“保存”,或者作为执行任务点击“保存并迁移”。
  • 迁移完成
    迁移结束“状态”栏显示“成功”,则迁移任务成功。
  • 迁移失败
    迁移结束“状态”栏显示“失败”,则迁移任务失败。失败后可点击详情查看日志有助于解决问题。

五、查看迁移报告及问题处理

迁移完成后,我们需要确认执行结果,包括迁移数据量,是否有错误发生,可以通过迁移日志和迁移结果进行查看。

  • “迁移日志”打印迁移任务执行后的日志,具体可分为“系统日志”、“Error日志”、“Info日志”。
  • “迁移结果”功能的工作区包括“任务执行批次”、“迁移对象”、“总数”、“成功数”、“失败数”、“略过数”、“操作”。您可以查看历史迁移任务执行的每次记录,以及每次迁移的对象、成功数、失败数、查看失败任务的错误日志。

结语

从 Oracle 到 KingbaseES 的迁移,不仅是技术层面的替换,更是企业国产化转型的重要一步。在迁移过程中我们最好按照一下步骤,遵循标准化流程、利用兼容优势、做好测试调优,即可实现 “平稳迁移、无缝衔接”。

  • 提前评估:摸清 Oracle 源库的对象和不兼容点,避免迁移中 “踩坑”;
  • 工具优先:善用 KDTS/KFS 等官方工具,减少手动操作,提升效率;
  • 充分测试:功能和性能测试必须覆盖所有业务场景,确保上线后稳定运行。

以上就是Oracle数据库移植到KingbaseES的全流程的详细内容,更多关于Oracle移植到KingbaseES的资料请关注脚本之家其它相关文章!

相关文章

  • Oracle表空间查看sql使用情况

    Oracle表空间查看sql使用情况

    我们在日常工作中查看表空间的使用情况大多数都是使用DBA。下面脚本之家小编给大家带来了oracle表空间查看sql使用情况的方法步骤,需要的童鞋参考下
    2016-05-05
  • oracle实现根据字段分组排序,取其第一条数据

    oracle实现根据字段分组排序,取其第一条数据

    这篇文章主要介绍了oracle实现根据字段分组排序,取其第一条数据方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • Oracle数据库中文显示???????解决办法

    Oracle数据库中文显示???????解决办法

    这两天刚刚使用Oracle,出现了好多不愉快的事情,下面分享一下我的一点经历,这篇文章主要给大家介绍了关于Oracle数据库中文显示???????的解决办法,需要的朋友可以参考下
    2024-04-04
  • Oracle如何使用PL/SQL调试存储过程

    Oracle如何使用PL/SQL调试存储过程

    这篇文章主要介绍了Oracle如何使用PL/SQL调试存储过程,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Oracle Index索引无效的原因与解决方法

    Oracle Index索引无效的原因与解决方法

    这篇文章主要给大家介绍了关于Oracle Index索引无效的原因与解决方法,文中通过示例代码以及图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • Oracle全量同步与增量同步方式

    Oracle全量同步与增量同步方式

    这篇文章主要介绍了Oracle全量同步与增量同步方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-06-06
  • 连接Oracle数据库时报ORA-12541:TNS:无监听程序的图文解决教程

    连接Oracle数据库时报ORA-12541:TNS:无监听程序的图文解决教程

    这篇文章主要介绍了连接Oracle数据库时报ORA-12541:TNS:无监听程序的图文解决教程,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08
  • Oracle 启动例程 STARTUP参数说明

    Oracle 启动例程 STARTUP参数说明

    Oracle启动例程:STARTUP参数说明(2008-07-28 20:51:20)标签:startup shutdown 事例 it 分类:Oracle数据管理
    2009-07-07
  • Oracle数据库中的LISTAGG函数使用示例及注意事项

    Oracle数据库中的LISTAGG函数使用示例及注意事项

    这篇文章主要给大家介绍了关于Oracle数据库中LISTAGG函数使用示例及注意事项的相关资料,listagg函数是Oracle 11.2推出的新特性,其主要功能类似于wmsys.wm_concat函数,即将数据分组后把指定列的数据再通过指定符号合并,需要的朋友可以参考下
    2024-08-08
  • 解决Oracle模拟事务提交、表锁,处理表锁问题

    解决Oracle模拟事务提交、表锁,处理表锁问题

    这篇文章主要介绍了Oracle模拟事务提交、表锁,处理表锁问题,通过可视化工具navicat执行插入语句,发现虽然我们设置了不自动提交,这里还是插入成功了,这里给大家介绍下手动提交事务流程,需要的朋友可以参考下
    2022-09-09

最新评论