分享

达梦数据库系统移植的基本步骤

李白 发表于 2023-8-29 11:28:51 [显示全部楼层] 回帖奖励 阅读模式 关闭右栏 0 359
一、 分析系统
分析系统的目的在于了解系统,判断系统移植的工作量及确定移植工作的重点和方案,主要包括以下一些内容:
1. 后台操作系统是什么及其版本信息,Windows、Unix、Linux等。
2. 后台数据库是什么及其版本信息,是SQL Server、Oracle、Informix还是其它。
3. 前台开发工具是什么及其版本信息,是.NET、JBuilder、Delphi还是其它。
4. 应用系统采用了什么开发模式,C/S还是B/S模式。
5. 应用系统使用的接口,常用的如ODBC、OLEDB、JDBC;如果是采用通用的接口,重点将转向后台数据库的移植;如果是采用一些特别的专用接口如OCI、API或者自定义的接口标准,则需要进行相关接口的开发,这时候移植工作重点将转向接口的开发上面来。
6. 相关的一些开发组件及其版本信息。
7. 相关的运行环境及其版本信息,如Tomcat、.NET Framework等。
8. 是否用到第三方的开发工具和平台,如SuperMap等。
9. 数据库的相关信息,主要有几个库,这些库之间的关系。
10. 涉及到的数据类型,常规的如CHAR、VARCHAR、INT等,这些各种数据库一般都支持,如果系统用到了如日期、时间、时间戳、文本、图像等类型,在移植的时候需要注意各种数据库之间的一些差异,主要是关注长度、精度、标度信息,有时候需要做些类型转换,如在Oracle中的VARCHAR(8000),在达梦数据库中可考虑将其转换成TEXT类型或采用16KB以上的建库模式加以解决。
11. 注意表的定义信息,主要是关注自定义的数据类型、自定义的缺省值,因SQL Server等数据库可创建自定义的数据类型和自定义的缺省值,而使用达梦的DTS工具无法将这些信息转换出来,需要在原系统中查找。
12. 是否使用到了视图、存储过程、存储函数、触发器、序列等;如果没有使用到这些,后台数据库的移植工作将主要是进行数据迁移;如果用到了这些,且数量较多,后台数据库的移植工作将是脚本的移植转换工作。
13. 是否用到了后台数据库的系统字典,因各数据库的系统字典格式和内容均不一样,这时候需要分析原数据库的系统字典的涵义,只能根据使用的实际情况作相应的处理。
14. 系统的运行规模和效率要求,如并发访问量,使用的频度,时间响应要求,主要是确定优化的方案,如果要求不高,优化的时候主要是采用创建索引的方法,如果要求较高,可考虑采用改写SQL语句的方法来进行,甚至考虑改写程序逻辑。
15. 是否有其它的特别的要求,如安全控制、双机热备、数据同步等,如果有这些要求,移植工作的重点和难点将转向这些问题的解决。

二、 确定方案
首先应确定系统移植工作的主承担方,即以应用软件开发商为主还是以数据库供应商为主;如以应用软件开发商为主,则数据库供应商应提供该数据库的技术支持服务,主要负责和承担数据库差异的解释工作;如以数据库供应商为主,则应用软件开发商则应提供对应用系统比较熟悉的技术人员配合移植工作。
一般来讲移植工作分为后台数据库的移植和前台应用系统的移植。

搭建环境
搭建环境包括搭建原系统运行环境和新系统环境,便于后续做功能和性能对比测试。

系统移植
数据库系统移植主要包括功能移植、功能测试和效率优化。在功能移植的过程中,保持一个原则就是不改变其应用逻辑,因为在功能移植的阶段重点是在解决系统差异上面,如果过多的考虑应用逻辑问题,移植工作的进度将会受到影响,也增加了移植工作的难度,同时如改变应用的程序逻辑,将存在功能修改错误的风险。

在进行后台数据库移植的时候,最好找一个比较方便操作,便于进行内容查找、内容替换和差异对比的编辑工具,如使用Vc的编辑器,Beyond Compare等工具,也可以辅助使用版本控制工具,如CVS等,因为移植过程中需要经常进行修改,这些工具可起到一个很好的辅助作用。

后台数据库的移植工作主要是脚本的移植和数据迁移工作。一般采用的顺序是先进性脚本的移植,再进行数据的迁移,这样做的好处主要有以下的几点:
1. 整理好脚本之后,便于快速搭建移植环境。
2. 有了脚本文件,能够对系统有一个整体的了解,便于对系统的把握。
3. 容易进行相应的特殊处理,如缺省值、类型、主键、外键等的处理。
4. 便于存储模块的移植。
5. 便于优化系统等。
当后台数据库中用到的存储模块、触发器等较多的时候,并且脚本长而复杂,这时候最好进行多人合作。
前台系统的移植主要是连接串的修改,一些差异的修改,如SQL参数的处理等,因应用系统千变万化,只能具体情况具体对待。
在移植的过程中注意做好修改记录,便于分析查找问题,这就是达梦数据库存储过程的特点。

三、系统测试
功能移植完成之后,需要进行一个完整性测试,主要包括功能测试和性能测试,测试的目的如下:
1. 测试功能是否正确,一是看程序能否执行,而是看结果是否正确,如果不对,可跟踪达梦日志,分析问题产生的原因进行相应的修改。
2. 测试执行效率,将用户反映慢的地方记录下来,效率优化的时候进行处理。

功能测试一般采用黑盒测试的方式进行,按照系统的功能点进行逐一测试,并做好测试记录,测试主要考察功能测试点是否能够正常执行同时要考察测试结果数据是否正确。

在进行性能测试前,可使用自动化的测试工具,加大测试数据量。性能测试在于找出系统运行慢的地方,做好相关的记录,性能测试可以辅助采用一些自动化的工具,如Loadrunner等;根据需要,也可以编写一些有针对性的测试用例,加强系统性能测试。

错误修改

试读已结束,请付费阅读全文。

  本文只能试读34%,付费后可阅读全文。 

版权说明:论坛帖子主题均由合作第三方提供并上传,若内容存在侵权,请进行举报

没找到任何评论,期待你打破沉寂

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

联系在线客服