一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術(shù)及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術(shù)|

服務器之家 - 數(shù)據(jù)庫 - Oracle - DB2數(shù)據(jù)庫切換為oracle數(shù)據(jù)庫經(jīng)驗教訓總結(jié)(必看篇)

DB2數(shù)據(jù)庫切換為oracle數(shù)據(jù)庫經(jīng)驗教訓總結(jié)(必看篇)

2020-01-09 15:20jingxian Oracle

下面小編就為大家?guī)硪黄狣B2數(shù)據(jù)庫切換為oracle數(shù)據(jù)庫經(jīng)驗教訓總結(jié)(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

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

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

1、我們的主鍵基本上都采用共的是Sequence,沒有采用自動增長作為主鍵。

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

DB2獲取的方法

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

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

例如:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
/// <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ù)庫執(zhí)行語句錯誤");
     }
     finally
     {
       dbconn.Close();
     }
   }

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

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

ORA-00911: 無效字符

3、部分數(shù)據(jù)庫類型不支持,部分函數(shù)沒有。

沒有XML,數(shù)據(jù)類型。雙精度浮點數(shù)字數(shù)據(jù)類型在DB2是DOUBLE,在Oracle是BINARY_DOUBLE

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

這幾個函數(shù)YEAR,MONTH,DAY沒有

條件in中的數(shù)據(jù)有限制,否則ORA-01795: 列表中的最大表達式數(shù)為 1000

4、視圖定義中表不能使用as。

?
1
2
3
4
5
6
7
8
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不會字符串轉(zhuǎn)為日期類型。

在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小時,如果時小時數(shù)是下午的13點就會出錯

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

在DB2中可以保存2016-04-14這樣沒有時間的日期,但在Oracle中好像不行,也導致了很多問題。

總之,這次切換數(shù)據(jù)庫還算順利,但教訓也不少,由于系統(tǒng)在七八年前設(shè)計,沒有考慮過切換數(shù)據(jù)庫的問題,因此使用數(shù)據(jù)庫函數(shù)時就沒有考慮數(shù)據(jù)庫函數(shù)的通用型,但因為使用了ORM映射工具ActiveRecord,修改也很少。如果使用大量的存儲過程,估計就有很多工作量了。在日期設(shè)計方面,應該根據(jù)具體實際設(shè)計類型了,例如對于2016-04-14格式的數(shù)據(jù)就可以采用字符串,沒必要使用日期類型導致不必要的錯誤。

以上這篇DB2數(shù)據(jù)庫切換為oracle數(shù)據(jù)庫經(jīng)驗教訓總結(jié)(必看篇)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持服務器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久伊人精品青青草原2021 | 国产欧美一区二区三区久久 | 9l桃色| 明星乱亚洲 | 欧美一级久久久久久久大片 | 小鸟酱在线看 | 91小视频在线观看免费版高清 | 精品播放 | 亚州在线视频 | 国产亚洲人成网站天堂岛 | 男男gaygays国内 | 法国女佣系列在线播放 | 国产小情侣自拍 | 国产三区二区 | 欧美精品99久久久久久人 | 九九精品国产兔费观看久久 | 关晓彤被调教出奶水的视频 | 亚洲视频在线免费 | 91aaa免费免费国产在线观看 | 91制片厂制作果冻传媒2021 | 特黄特黄一级高清免费大片 | 波多野结衣中文丝袜字幕 | 麻豆婷婷 | 免费日批软件 | 91调教| 国产91一区二区在线播放不卡 | 亚洲成人精品久久 | 91精品国产9l久久久久 | 亚洲精品久久麻豆蜜桃 | 国产一区二区三区水野朝阳 | 好紧好爽再叫浪一点点潘金莲 | 国产51社区精品视频资源 | 日本一片免费观看高清完整 | 皇上好大好硬好涨好深好爽 | 国产91精选在线观看麻豆 | 无耻三级在线观看 | 日韩免费高清专区 | 精品欧美一区二区三区在线观看 | 99久久6er热免费精品 | 日本丰满大乳乳奶 | 日本-区二区三区免费精品 日本破处 |