好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > DB2數據庫切換為oracle數據庫經驗教訓總結(必看篇)

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
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不會字符串轉為日期類型。

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

您可能感興趣的文章:
  • Oracle數據庫遷移方案
  • oracle 數據庫數據遷移解決方案
  • mysql數據庫遷移至Oracle數據庫
  • oracle數據遷移到db2數據庫的實現方法(分享)

標簽:自貢 百色 中衛 紹興 昭通 海東 寧波 遼源

巨人網絡通訊聲明:本文標題《DB2數據庫切換為oracle數據庫經驗教訓總結(必看篇)》,本文關鍵詞  DB2,數據庫,切換,為,oracle,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《DB2數據庫切換為oracle數據庫經驗教訓總結(必看篇)》相關的同類信息!
  • 本頁收集關于DB2數據庫切換為oracle數據庫經驗教訓總結(必看篇)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 拍裸戏时被C了H辣文小说| 桃花社区视频| 欧美黄色三级视频| 国产一级二级AV女免费| 太古里健身2分47视频| 伊人草久久| 啊啊啊啊啊受不了了| 亚洲乱码在线观看| 特送在线观看完整高清免费版| 国产精品久久久久久无码专区 | 国产aa毛片| ??国产微拍精品一区| 91制片国产李宗瑞秘?| 精品韩国一级久久A片性教育片| 91国偷自产一区二区三区老熟女| 妖精动漫登录页面入口界面| 亲嘴伸进内衣揉胸口激烈视频.| 欧美一级做a爰片免费视频观看| ?交+视频+在线观看女4小说| 手机成人在线视频| 国产精久久久久久精品| 小说涩| 哇嘎电影免费观看| 16美女偷拍秘?洗澡| 污到下面流水的视频| 97午夜电影| 《人妻上司》风间由美3| 开心丁五香月婷kkk48| 粗暴h疼哭np各种play| 少妇又紧又深又湿又爽视频| 下载黄色软件.| 国产一级做a爰片久久毛片男| 天天操天天操天天操香蕉| 欧美黄色a级片| 三攻一受4p嗯啊巨肉寝室 1 0视频| 狠狠色综合久久丁香婷婷| 久久久无码AV精品亚渊源阁| 99久久国产精品免费热99| 美女福利一区| 啊啊啊好大好粗| 黄色污污的网站|