由于DB2数据库使用的人太少,公司有没有专业的DBA,决定把数据库从DB2数据库切换为oracle数据库,本以为很简单,可当真的切换时,却发现,有很多东西出乎意料。

由于系统底层使用的是ORM映射工具,由于没有使用存储过程,自定义函数,触发器,因此我以为系统改动不大,但发现的问题却不少。
1、我们的主键基本上都采用共的是Sequence,没有采用自动增长作为主键。
但获取Sequence在两种数据库中是不相同的。
DB2获取的方法
values next value for eas.seq_SequenceNameOracle中获取的方法
select seq_SequenceName.nextval from dual2我们底层采用的是ORM映射工具ActiveRecord,发现执行SQL时语句末尾不能有分号,太奇怪了。这个问题似乎是ActiveRecord本身的问题
例如:
/// <summary>
/// 得到第一行第一列的值
/// </summary>
/// <param name="sqlstr"></param>
/// <returns></returns>
public object ScalarBySQL(String sqlstr)
{
ISession sess = ActiveRecordMediator.GetSessionFactoryHolder().CreateSession(typeof(ActiveRecordBase));
IDbConnection dbconn = sess.Connection;
try
{
IDbCommand dbCommand = dbconn.CreateCommand();
dbCommand.CommandText = sqlstr;
object thisReader = dbCommand.ExecuteScalar();
return thisReader;
}
catch (Exception ex)
{
LogInfo.Error(sqlstr + ex.Message);
throw new Exception("数据库执行语句错误");
}
finally
{
dbconn.Close();
}
}
例如:sqlstr="select * FROM EAS.T_HRWagesLog where HRWL_Month='201603'";
时在DB2,Oracle中都能正常执行,但如果末尾有一个分号;则在Oracle中直接就是一个错误
ORA-00911: 无效字符
3、部分数据库类型不支持,部分函数没有。
没有XML,数据类型。双精度浮点数字数据类型在DB2是DOUBLE,在Oracle是BINARY_DOUBLE
由于使用了一个工具导出的DOUBLE,直接转为了NUMBER(13),导致没有小数部分,导致了大量错误。
这几个函数YEAR,MONTH,DAY没有
条件in中的数据有限制,否则ORA-01795: 列表中的最大表达式数为 1000
4、视图定义中表不能使用as。
create view ViewName as select a.HWD_User_FK,b.u_name from T_HRWxData as a join T_user as b on a.HWD_User_FK=b.u_id如上的SQL在Server SQL,DB2中都可以使用,但在Oracle中不能使用,需要把as去掉 create view ViewName as select a.HWD_User_FK,b.u_name from T_HRWxData a join T_user b on a.HWD_User_FK=b.u_id
5、最大的问题是日期问题
select * FROM EAS.T_HRWxData where HWD_Date>='2016-04-14'如上的SQL,在SQL Server,DB2中可以,但在Oracle中是错误的,oracle不会字符串转为日期类型。
在Oracle可以修改为
select * FROM EAS.T_HRWxData where HWD_Date>=to_date('2016-04-14','yyyy-mm-dd')
包含小时的日期格式处理24小时
to_date('2016-03-06 13:12:09','yyyy-mm-dd hh24:mi:ss')
包含小时的日期格式处理12小时,如果时小时数是下午的13点就会出错
to_date('2016-03-06 01:12:09','yyyy-mm-dd hh:mi:ss')
在DB2中可以保存2016-04-14这样没有时间的日期,但在Oracle中好像不行,也导致了很多问题。
总之,这次切换数据库还算顺利,但教训也不少,由于系统在七八年前设计,没有考虑过切换数据库的问题,因此使用数据库函数时就没有考虑数据库函数的通用型,但因为使用了ORM映射工具ActiveRecord,修改也很少。如果使用大量的存储过程,估计就有很多工作量了。在日期设计方面,应该根据具体实际设计类型了,例如对于2016-04-14格式的数据就可以采用字符串,没必要使用日期类型导致不必要的错误。
以上这篇DB2数据库切换为oracle数据库经验教训总结(必看篇)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
# db2数据库与oracle
# 比较SQL Server与Oracle、DB2数据库的一些知识
# 比较SQL Server与Oracle、DB2
# oracle数据迁移到db2数据库的实现方法(分享)
# DB2和 Oracle的并发控制(锁)的比较
# db2与oracle的sql语句有什么不同
# 的是
# 但在
# 给大家
# 存储过程
# 的人
# 主键
# 就会
# 就有
# 浮点
# 有很多
# 都能
# 两种
# 这个问题
# 用了
# 希望能
# 很简单
# 能有
# 问题是
# 自定义
# 还算
相关文章:
如何使用Golang table-driven基准测试_多组数据测量函数效率
南宁网站建设制作定制,南宁网站建设可以定制吗?
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
如何使用Golang安装API文档生成工具_快速生成接口文档
头像制作网站在线制作软件,dw网页背景图像怎么设置?
建站VPS能否同时实现高效与安全翻墙?
建站之星如何优化SEO以实现高效排名?
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
黑客如何利用漏洞与弱口令入侵网站服务器?
制作网页的网站有哪些,电脑上怎么做网页?
建站之星后台管理如何实现高效配置?
企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
建站之星如何保障用户数据免受黑客入侵?
如何快速搭建高效WAP手机网站吸引移动用户?
网站制作网站,深圳做网站哪家比较好?
重庆市网站制作公司,重庆招聘网站哪个好?
如何登录建站主机?访问步骤全解析
北京的网站制作公司有哪些,哪个视频网站最好?
攀枝花网站建设,攀枝花营业执照网上怎么年审?
Swift中swift中的switch 语句
制作营销网站公司,淘特是干什么用的?
,sp开头的版面叫什么?
高性能网站服务器配置指南:安全稳定与高效建站核心方案
南平网站制作公司,2025年南平市事业单位报名时间?
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
如何用IIS7快速搭建并优化网站站点?
广平建站公司哪家专业可靠?如何选择?
建站之星如何开启自定义404页面避免用户流失?
长沙企业网站制作哪家好,长沙水业集团官方网站?
如何基于PHP生成高效IDC网络公司建站源码?
东莞专业网站制作公司有哪些,东莞招聘网站哪个好?
C++中引用和指针有什么区别?(代码说明)
如何有效防御Web建站篡改攻击?
深入理解Android中的xmlns:tools属性
阿里云网站制作公司,阿里云快速搭建网站好用吗?
建站主机选哪种环境更利于SEO优化?
如何在Ubuntu系统下快速搭建WordPress个人网站?
网站制作壁纸教程视频,电脑壁纸网站?
建站之星安装步骤有哪些常见问题?
公司网站制作价格怎么算,公司办个官网需要多少钱?
建站之星CMS五站合一模板配置与SEO优化指南
已有域名如何免费搭建网站?
常州自助建站工具推荐:低成本搭建与模板选择技巧
如何正确下载安装西数主机建站助手?
专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
如何在新浪SAE免费搭建个人博客?
*请认真填写需求信息,我们会在24小时内与您取得联系。