亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

DB2數據庫切換為oracle數據庫經驗教訓總結(必看篇)

2024-08-29 13:59:59
字體:
來源:轉載
供稿:網友

由于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 ViewNameasselect 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 ViewNameasselect 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數據庫經驗教訓總結(必看篇)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美精品少妇videofree| 日韩国产精品亚洲а∨天堂免| 久久久久中文字幕| 国产91色在线|| 福利微拍一区二区| 欧美国产日韩一区| 国产偷亚洲偷欧美偷精品| 97国产真实伦对白精彩视频8| 久久亚洲精品中文字幕冲田杏梨| 欧美老肥婆性猛交视频| 久久久国产精品视频| 91av福利视频| 一区二区三区美女xx视频| 久久免费精品日本久久中文字幕| 91香蕉嫩草影院入口| 欧美一区二区三区……| 精品福利樱桃av导航| 奇米成人av国产一区二区三区| 日韩高清a**址| 国产成人精品电影| 国产午夜精品免费一区二区三区| 国产91亚洲精品| 欧美床上激情在线观看| 日韩中文字幕精品视频| 欧美性猛交xxxx乱大交| 中文字幕亚洲一区二区三区五十路| 亚洲a一级视频| 92版电视剧仙鹤神针在线观看| 欧美综合一区第一页| 萌白酱国产一区二区| 日韩亚洲成人av在线| 亚洲欧美资源在线| 成人激情黄色网| 91亚洲国产成人精品性色| 日韩av日韩在线观看| 在线电影欧美日韩一区二区私密| 亚洲区中文字幕| 欧美激情一级精品国产| 91在线视频成人| 欧美性猛交xxxxx免费看| 国产精品成av人在线视午夜片| 欧美激情在线一区| 欧美成人免费大片| 欧美成人精品影院| 日韩国产激情在线| 久久精品中文字幕一区| www.亚洲免费视频| 欧美影院久久久| 亚洲一级免费视频| 成人免费激情视频| 日韩av综合中文字幕| 久久人人爽人人爽爽久久| 欧美高清视频在线观看| 亚洲第一av网站| 青草青草久热精品视频在线网站| 国产精品久久久久久久久久小说| 国产成人免费av电影| 国产精品久久在线观看| 国产日韩欧美电影在线观看| 亚洲欧洲在线播放| 亚洲国产精品久久久久秋霞不卡| 国产精品欧美在线| 国产女精品视频网站免费| 日韩欧美主播在线| 欧美极品美女电影一区| 狠狠躁夜夜躁人人爽超碰91| 国产成人久久久精品一区| 亚洲一区二区三区毛片| 欧美日韩性生活视频| 国产一区二中文字幕在线看| 亚洲最大成人免费视频| 国产成人黄色av| 亚洲少妇激情视频| 国内精品模特av私拍在线观看| 亚洲第一福利在线观看| 国产成人+综合亚洲+天堂| 中文字幕欧美视频在线| 国模精品视频一区二区| 日韩成人在线视频观看| 亚洲美女中文字幕| 欧美激情视频免费观看| 精品无码久久久久久国产| 久久精品这里热有精品| 国产va免费精品高清在线观看| 中文字幕成人精品久久不卡| 欧美日韩爱爱视频| 亚洲国产精品久久久久秋霞不卡| 91亚洲va在线va天堂va国| 日本国产精品视频| 日韩高清电影免费观看完整版| 国产亚洲精品综合一区91| 日本高清视频一区| 久久人人爽人人爽人人片av高清| 欧美性xxxxx极品娇小| 亚洲va久久久噜噜噜| 欧美大全免费观看电视剧大泉洋| 丝袜情趣国产精品| 国产黑人绿帽在线第一区| 日韩国产在线播放| 国产成人亚洲综合91精品| 国产精品久久精品| 黑人巨大精品欧美一区免费视频| 久久中文字幕在线视频| 久久久久亚洲精品成人网小说| 日本一区二三区好的精华液| 久久夜色精品国产| 久久精品国产亚洲精品2020| 国内精品久久久久久中文字幕| 91欧美精品午夜性色福利在线| 欧美放荡办公室videos4k| 欧美性视频在线| 午夜精品理论片| 在线播放国产一区二区三区| 日韩欧美a级成人黄色| 亚洲电影成人av99爱色| 欧美日韩国产页| 精品久久久久久久久国产字幕| 精品二区三区线观看| 最新91在线视频| 色狠狠久久aa北条麻妃| 国产精品久久久久久久久粉嫩av| 欧美日韩福利电影| 国产精品高潮在线| 国产日韩欧美在线播放| 国产欧美最新羞羞视频在线观看| 一本色道久久88精品综合| 日韩av大片在线| 青青草国产精品一区二区| 欧美国产欧美亚洲国产日韩mv天天看完整| 久久久精品欧美| 国产精品久久久久久av下载红粉| 亚洲精品久久久久久久久| 欧美成年人视频网站欧美| 亚洲在线免费视频| 琪琪第一精品导航| 亚洲福利在线看| 久久久久国产精品一区| 成人国产精品久久久| 成人精品一区二区三区电影免费| 精品亚洲永久免费精品| 亚洲国产天堂久久综合| 亚洲精品天天看| 亚洲欧美日韩综合| 亚洲黄页视频免费观看| 久久久久久久999精品视频| 欧美高清在线观看| 国产精品视频久久久| 欧美日韩在线观看视频小说| 77777少妇光屁股久久一区| 成人欧美一区二区三区黑人| 亚洲精品成人免费| 亚洲一区二区三区sesese| 国内精品久久影院| 欧美性猛交xxxx黑人猛交| 日韩大陆毛片av| 国产国语videosex另类| 欧美性猛交xxxx久久久| 国产深夜精品福利| 色婷婷综合成人av| 亚洲色图13p| 欧美与黑人午夜性猛交久久久| 91黑丝高跟在线| 狠狠干狠狠久久| 久久精品一偷一偷国产|