在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

DB2数据库切换为oracle数据库的示例分析

121次阅读
没有评论

共计 2090 个字符,预计需要花费 6 分钟才能阅读完成。

丸趣 TV 小编给大家分享一下 DB2 数据库切换为 oracle 数据库的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

由于 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
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 去掉

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 hh34:mi:ss)

包含小时的日期格式处理 12 小时,如果时小时数是下午的 13 点就会出错

to_date(2016-03-06 01:12:09 , yyyy-mm-dd hh:mi:ss)

在 DB2 中可以保存 2016-04-14 这样没有时间的日期,但在 Oracle 中好像不行,也导致了很多问题。

以上是“DB2 数据库切换为 oracle 数据库的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注丸趣 TV 行业资讯频道!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-04发表,共计2090字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 日韩精品欧美国产精品亚 | 一区二区日韩欧美 | 6969视频| 看国产毛片 | 91久久国产精品 | 久久人妻无码中文字幕 | 欧美人妻aⅴ中文字幕 | 日韩av无码中文无码不卡电影 | 欧美综合自拍亚洲综合 | 亚洲成av人片无码天堂下载 | 亚洲av日韩精品一区二区三区 | 久久精品视频在线看99 | 色偷偷av男人的天堂 | 色偷偷久久一区二区三区 | 免费观看美女裸体网站 | 国产在线不卡一区二区三区 | 国产精品成人一区二区三区 | 日日摸夜夜爽久久综合 | 激性欧美激情在线 | 亚洲男人精品 | 中国少妇内射xxxx狠干 | 风流老熟女一区二区三区 | 免费一级做a爰片性视频 | 色综合久久无码五十路人妻 | 黄色aa级片 | 三级国产4国语三级在线 | 四虎在线永久视频观看 | 欧美又黄又嫩大片a级 | 色老板美国在线观看 | 大桥未久亚洲无av码在线 | 女人被狂躁c到高潮喷水一区二区 | xf在线a精品一区二区视频网站 | 国内精品久久久久久久 | 中文字幕精品亚洲无线码一区 | 香蕉精品高清在线观看视频 | 少妇放荡的呻吟干柴烈火动漫 | 成年女人免费视频播放体验区 | 国产一区二区三区四区在线 | 午夜日韩在线 | 久久国产高清一区二区三区 | 精品亚洲77777www |