oracle向达梦迁移工作量,从Oracle安全移植到国产达梦数据库的DBA实践

随着我国对信息安全和自主可控技术的日益重视,国产数据库在党政机关、军队和大型央企等行业中得到了快速应用。达梦数据库(以下简称DM)是国内数据库行业领军企业——达梦推出的一款自主可控的高性能数据库产品。

如何降低从Oracle到DM数据库移植的技术门槛,保障用户现有业务系统投资,美创DBA团队对Oracle安全移植到DM数据库的技术课题进行了研究实践。

从Oracle到DM的移植,主要包含以下工作

Ⅰ、 分析待移植系统,确定移植对象。

Ⅱ、 通过数据迁移工具 DTS 完成常规数据库对象及数据的迁移。

Ⅲ、 通过人工完成 PL/SQL 的移植。

Ⅳ、 移植完成后对移植的结果进行校验,确保移植的完整性和正确性。

Ⅴ、 对应用系统进行测试和优化。

具体移植攻略

1、 待移植系统分析

1. 1、信息采集,包括操作系统版本、数据库版本、应用开发平台、应用开发接口和需要移植的数据库对象;

1. 2、统计Oracle数据库基础信息;

1. 3、统计 Oracle 数据中的对象以及表数据量。

二、 准备移植环境

仅做移植兼容性测试。这里指的是用户或者开发商对于移植可能性和技术工作量的一个评估和确认工作,也就是尝试性的移植,移植后可能并不会立刻进行产品级的应用功能、性能、稳定性测试,在这种情况下,一般搭建最基础的移植环境即可,用虚拟机和物理机服务器都可以进行,且对配置无特别要求,满足基本运行条件即可;

为替换 Oracle

上线运行进行正式移植。在这种情况下,移植完成后,会对应用进行产品级全方位的功能点测试、性能测试、压力测试以及稳定性测试等集成测试。在这种情况下搭建移植环境,一定要优先采用物理服务器搭建,并且对于物理服务器的相关硬件配置要提出要求。

2. 1  DM 移植环境

2. 1.1、选择版本

版本优先选择完整安装版本,避免数据库客户端和服务器端存在版本不匹配带来的额外工作量,达梦在不同平台的不同版本上,安装包都会有差异,一定要采用严格匹配的原则。

2. 1.2、初始化参数

从 Oracle 移植到 DM 数据库,初始化参数建议:

(1)页大小 PAGE_SIZE

Oracle 也叫块大小(block),在 DM 数据库中,页大小可以为

4KB、8KB、16KB 或者 32KB,从 Oracle 移植到 DM,建议设置页大小为

8KB,一旦创建好了数据库,在该库的整个生命周期内,页大小都不能够改变。除了每个字段的最大长度限制外,每条记录总长度不能大于页面大小的一半。如果系统中存在或者以后可能存在含有较长的字符串类型的表,建议该参数设置为

16 或者 32。页大小设置越大,最后数据文件的物理大小就会越大,系统运行时,每次从磁盘调入内存的数据单位也就越大,所以此处要慎重。

(2)簇大小 EXTENT_SIZE

数据文件使用的簇大小,即每次分配新的段空间时连续的页数,只能是16页或32页,缺省使用

16 页,从 Oracle 移植到 DM 使用默认值就可。

(3)大小写敏感 CASE_SENSITIVE

DM

为了兼容不同的数据库,在初始化数据库的时候有一个参数字符串比较大小写敏感,用于确定数据库对象及数据是否区分大小写,默认为区分,不可更改。Oracle

迁移过来的系统,使用大小写敏感,以便和原来系统匹配。

(4)字符集 CHARSET

建议采用默认值 GB18030,如果需要国际字符可以采用Unicode,GB18030

数字字母占 1 个字节,普通汉字占 2 个字节,部分繁体及少数民族文字占 4 字节,Unicode 在达梦中采用 UTF-8 编码格式,欧洲的字母字符占 1 到

2 个字节, 亚洲的大部分字符占 3 个字节,附加字符为 4 个字节。如果只存储中文和字母数字,一般来说 GB18030 更节省空间一些。

2. 1.3、合理配置 INI参数

COMPATIBLE_MODE

参数,配置成兼容Oracle数据库模式。

在 INI 参数的

compatibility部分,还有其它的一些参数,在涉及到之前,尽量保持默认值,在移植准备的环节,先只调整这个参数就可以了,其它参数,在移植过程中,遇到了再具体分析。

2. 1.4、创建用户和表空间

移到系统管理员 SYSDBA 用户下和 MAIN 表空间下。首先需要分析本次移植

Oracle 源库需要移植的是哪一个或者哪几个用户的数据,然后分别创建这些需要移植的用户和对应的表空间;大多数情况下,我们需要移植的 Oracle

实例中可能存在有大量的用户,并不是所有的用户对象都是需要我们移植的,所以在移植准备阶段,一定要沟通明确清楚。

2. 2  Oracle 移植环境

在从 Oracle 向 DM7 进行移植准备阶段,也需要注意 Oracle

的移植环境:严禁在生产环境中直接迁移。因为移植首先是一个测试的工作,所以移植应该避免从Oracle生产环境数据库中直接进行移植,需要提前向应用开发商提出需要搭建一个测试环境,准备

Oracle 需要移植的环境和数据。直接从生产库上进行数据移植,有很多风险存在, 例如会影响生产库的效率,引发崩溃的可能等等。推荐使用 pl/sql

developer 工具进行移植测试工作。

3、 常规对象及数据迁移

常规对象指的是序列、表和视图,都可以通过达梦提供的数据迁移工具从 Oracle

完整的迁移到达梦数据库。

3. 1 制定迁移计划

3. 1.1、选择合理的迁移顺序:先迁移序列、再迁移表、最后迁移视图。

3. 1.2、对于数据量大的表单独迁移。

3. 1.3、对于分区表如果数据量没有超过 1

亿建议迁移成普通表,在分区列上创建索引。

3. 1.4、对于大字段较多的表,需要修改批量的行数,以免造成迁移工具内存溢出。

3. 2  Oracle 移植环境

序列对象一般不依赖其他模式对象,而被其他如表、过程所依赖,所以一般迁移过程中,

最先迁移序列对象。迁移序列方法:

3. 2.1、使用 DTS 工具迁移序列,此方法适用于批量迁移序列对象。DTS

工具使用方法可参考帮助-帮助主题。

3. 2.2、从源 Oracle

中获取序列定义,在目的库手动执行序列创建,此方法适用于所需迁移对象较少,或者对方法一中迁移出错的序列单独处理。

3. 3 表对象迁移

3. 3.1、一次性迁移

对于表比较少,数据量不大的系统,可以通过 DTS 采取一次性迁移。

3. 3.2、分批次迁移

对于表比较多,数据量大的系统,建议先迁移小表再进行大表的迁移,迁移时最好不用快速装载功能。

3. 4 视图对象迁移

3. 4.1、普通视图对象迁移

(1)使用 DTS 工具迁移视图,此方法适用于批量迁移视图对象。DTS

工具使用方法可参考帮助-帮助主题。

(2)从源 Oracle

中获取视图定义,在目的库手动创建视图,此方法适用于所需迁移对象较少,或者对方法一中迁移出错的视图单独处理。

3. 4.2、物化视图对象迁移

(1)使用 DTS

工具迁移物化视图,此方法适用于批量迁移物化视图对象。

(2)从源 Oracle

中获取物化视图定义,在目的库手动创建物化视图,此方法适用于所需迁移对象较少,或者对 a 方法中迁移出错的物化视图单独处理。

4、 PL/SQL 移植

接下来对自定义类型、存储过程、函数、触发器进行移植,可以使用达梦 DTS

工具进行迁移。如果遇到大量错误难以排查,也可以使用如下的方法进行分步迁移,导出待移植对象的脚本:

方法一:使用 PL/SQL DEVELOPER

等工具导出自定义类型、存储过程、函数、触发器等 PL/SQL 脚本。

方法二:在 sqlplus 中使用 Oracle

自带的包导出自定义类型、存储过程、函数、触发器等。

同理,其他类型如 TYPE, PACKAGE,PACKAGEBODY

等也可以用这种方法导出。

5、 移植后收尾工作

5. 1、更新统计信息

数据核对完成无问题后,应进行一次全库的统计信息更新工作。更新统计信息的目的在于大批量迁移数据后,可能会导致数据库优化器根据错误的统计信息得到错误的查询计划,严重影响查询性能。

5. 2、数据备份

再对数据更新完统计信息后,在数据量不大,磁盘空间足够的情况下应进行一次数据备份工作。数据备份有两种方式:正常停止数据库后,拷贝备份

data 文件夹;或者开启归档日志后,进行物理备份。

5. 3、整理对象脚本

整理所有数据库对象脚本,这是为了对项目移植情况进行记录和备份,方便再次进行数据迁移。备份的数据库对象脚本包括:序列定义及当前值,表定义,索引定义,视图定义,函数定义,存储过程定义,包及包体定义、自定义类型和同义词定义。

6、 系统测试与优化

数据库和应用系统移植完毕后开启 sql

日志,对系统进行全面测试,排除移植过程中错误的地方,对慢的 sql 语句进行优化。

在功能测试和性能测试的时候可以开启 SQL

日志,然后通过日志分析工具从执行时间和执行次数两个维度对 SQL 日志进行分析,生产分析结果,然后根据分析结果对系统性能进行优化。

结语

在数据库国产化进程中,大量Oracle数据库向国产数据库移植是一个长期、复杂的过程,需要管理、业务和运维各方的充分协作。美创DBA团队对Oracle到国产数据库的移植场景进行了充分探索和实践,可以结合客户实际环境和个性化需求提供安全、高效的移植服务,并确保数据库移植后生产业务系统的持续稳定运行。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在将 Oracle 数据库迁移达梦数据库时,需要注意转换精度的问题。Oracle 数据库和达梦数据库在数值类型的精度上存在差异,需要进行转换。 在 Oracle 数据库中,数值类型包括 NUMBER、FLOAT 和 BINARY_FLOAT 等。其中,NUMBER 类型可以指定精度和小数位数,例如 NUMBER(10,2) 表示精度为 10,小数位数为 2。FLOAT 和 BINARY_FLOAT 类型的精度由系统自动确定。 而在达梦数据库中,数值类型包括 NUMBER、FLOAT 和 DOUBLE 等。其中,NUMBER 类型可以指定精度和小数位数,例如 NUMBER(10,2) 表示精度为 10,小数位数为 2。FLOAT 和 DOUBLE 类型的精度由系统自动确定。 在将 Oracle 数据库迁移达梦数据库时,需要注意以下几点: 1. 转换精度:需要将 Oracle 数据库中的数值类型转换为达梦数据库中相应的数据类型,并注意转换精度的问题。在转换过程中,需要确保达梦数据库中的精度和小数位数足够满足业务需求。 2. 数据溢出:由于 Oracle 数据库和达梦数据库的数值类型精度不同,可能会出现数据溢出的情况。在进行数据迁移前,需要检查 Oracle 数据库中的数据是否会出现溢出的情况,并根据需要进行数据类型的转换或调整达梦数据库的精度。 3. 数据类型的兼容性:Oracle 数据库和达梦数据库的数据类型不完全相同,需要进行数据类型的兼容性检查。在进行数据迁移前,需要检查 Oracle 数据库中的数据类型是否与达梦数据库中的数据类型兼容,如不兼容,需要进行相应的数据类型转换。 总之,在进行 Oracle 数据库向达梦数据库迁移时,需要仔细检查数据类型的精度和兼容性,以确保数据迁移的准确性和完整性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值