久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

DB2數(shù)據(jù)庫(kù)切換為oracle數(shù)據(jù)庫(kù)的示例分析

共計(jì) 2090 個(gè)字符,預(yù)計(jì)需要花費(fèi) 6 分鐘才能閱讀完成。

丸趣 TV 小編給大家分享一下 DB2 數(shù)據(jù)庫(kù)切換為 oracle 數(shù)據(jù)庫(kù)的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

由于 DB2 數(shù)據(jù)庫(kù)使用的人太少,公司有沒(méi)有專(zhuān)業(yè)的 DBA,決定把數(shù)據(jù)庫(kù)從 DB2 數(shù)據(jù)庫(kù)切換為 oracle 數(shù)據(jù)庫(kù),本以為很簡(jiǎn)單,可當(dāng)真的切換時(shí),卻發(fā)現(xiàn),有很多東西出乎意料。

由于系統(tǒng)底層使用的是 ORM 映射工具,由于沒(méi)有使用存儲(chǔ)過(guò)程,自定義函數(shù),觸發(fā)器,因此我以為系統(tǒng)改動(dòng)不大,但發(fā)現(xiàn)的問(wèn)題卻不少。

1、我們的主鍵基本上都采用共的是 Sequence,沒(méi)有采用自動(dòng)增長(zhǎng)作為主鍵。

但獲取 Sequence 在兩種數(shù)據(jù)庫(kù)中是不相同的。

DB2 獲取的方法

values next value for eas.seq_SequenceNameOracle 中獲取的方法

select seq_SequenceName.nextval from dual2 我們底層采用的是 ORM 映射工具 ActiveRecord,發(fā)現(xiàn)執(zhí)行 SQL 時(shí)語(yǔ)句末尾不能有分號(hào),太奇怪了。這個(gè)問(wèn)題似乎是 ActiveRecord 本身的問(wèn)題

例如:

 ///  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( 數(shù)據(jù)庫(kù)執(zhí)行語(yǔ)句錯(cuò)誤 
 }
 finally
 { dbconn.Close();
 }
 }

例如:sqlstr= select * FROM EAS.T_HRWagesLog where HRWL_Month= 201603

時(shí)在 DB2,Oracle 中都能正常執(zhí)行,但如果末尾有一個(gè)分號(hào); 則在 Oracle 中直接就是一個(gè)錯(cuò)誤

ORA-00911: 無(wú)效字符

3、部分?jǐn)?shù)據(jù)庫(kù)類(lèi)型不支持,部分函數(shù)沒(méi)有。

沒(méi)有 XML,數(shù)據(jù)類(lèi)型。雙精度浮點(diǎn)數(shù)字?jǐn)?shù)據(jù)類(lèi)型在 DB2 是 DOUBLE,在 Oracle 是 BINARY_DOUBLE

由于使用了一個(gè)工具導(dǎo)出的 DOUBLE,直接轉(zhuǎn)為了 NUMBER(13),導(dǎo)致沒(méi)有小數(shù)部分,導(dǎo)致了大量錯(cuò)誤。

這幾個(gè)函數(shù) YEAR,MONTH,DAY 沒(méi)有

條件 in 中的數(shù)據(jù)有限制,否則 ORA-01795: 列表中的最大表達(dá)式數(shù)為 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、最大的問(wèn)題是日期問(wèn)題

select * FROM EAS.T_HRWxData where HWD_Date = 2016-04-14 如上的 SQL,在 SQL Server,DB2 中可以,但在 Oracle 中是錯(cuò)誤的,oracle 不會(huì)字符串轉(zhuǎn)為日期類(lèi)型。

在 Oracle 可以修改為

select * FROM EAS.T_HRWxData where HWD_Date =to_date(2016-04-14 , yyyy-mm-dd)

包含小時(shí)的日期格式處理 24 小時(shí)

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

包含小時(shí)的日期格式處理 12 小時(shí),如果時(shí)小時(shí)數(shù)是下午的 13 點(diǎn)就會(huì)出錯(cuò)

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

在 DB2 中可以保存 2016-04-14 這樣沒(méi)有時(shí)間的日期,但在 Oracle 中好像不行,也導(dǎo)致了很多問(wèn)題。

以上是“DB2 數(shù)據(jù)庫(kù)切換為 oracle 數(shù)據(jù)庫(kù)的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注丸趣 TV 行業(yè)資訊頻道!

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-08-04發(fā)表,共計(jì)2090字。
轉(zhuǎn)載說(shuō)明:除特殊說(shuō)明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請(qǐng)注明出處。
評(píng)論(沒(méi)有評(píng)論)
主站蜘蛛池模板: 合肥市| 伊吾县| 定陶县| 淮滨县| 大名县| 河北区| 朝阳县| 喀喇| 英吉沙县| 尼玛县| 东乌珠穆沁旗| 贵定县| 崇州市| 苏尼特左旗| 比如县| 崇礼县| 淄博市| 江津市| 浮山县| 鄂托克旗| 荆门市| 宜州市| 蓝田县| 教育| 塔河县| 祁门县| 韶山市| 汉沽区| 财经| 彭阳县| 隆德县| 承德市| 萨嘎县| 贵港市| 江山市| 平遥县| 加查县| 克什克腾旗| 英吉沙县| 淮滨县| 黑山县|