• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >oracle > DB2数据库切换为oracle数据库经验教训总结(必看篇)

DB2数据库切换为oracle数据库经验教训总结(必看篇)

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了db2数据库,db2数据库下载,db2数据库培训,北京db2数据库培训,db2数据库入门教程等相关知识,希望本文的分享对您有所帮助

由于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();
      }
    }
</div>

例如: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

</div>

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数据库经验教训总结(必看篇)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • DB2数据库切换为oracle数据库经验教训总结(必看篇)

相关文章

  • 2017-05-11Oracle高级队列(Advanced Queue)简单实例
  • 2017-05-11PL/SQL Developer连接64位的Oracle图文教程
  • 2017-05-11Linux ORCLE数据库增量备份脚本
  • 2017-05-11在Tomcat服务器下使用连接池连接Oracle数据库
  • 2017-05-11ORACLE SQL-UPDATE、DELETE、INSERT优化和使用技巧分享
  • 2017-09-17Oracle12c通过SQL Developer工具调试procedure报错: ORA-24247解决方法
  • 2017-05-11Oracle时间日期操作方法小结第1/2页
  • 2017-05-11oracle 性能优化建议小结
  • 2017-05-11ORACLE学习笔记-添加更新数据函数篇
  • 2017-05-11oracle用什么SQL语句判断表存不存在

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • oracle常用命令
    • oracle 监听 lsnrctl 命令 (推荐)
    • Oracle Report中加入下载超链接操作方法
    • Oracle存储过程基本语法介绍
    • oracle 12c安装教程(window)
    • catalog方式的rman备份与恢复示例
    • JDBC连接集群数据库的方法
    • Oracle删除死锁进程的方法
    • 常见数据库系统比较 Oracle数据库
    • Oracle中的MD5加密详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有