成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

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

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

成都創(chuàng)新互聯(lián)公司專注于二道江企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站設(shè)計(jì),成都做商城網(wǎng)站。二道江網(wǎng)站建設(shè)公司,為二道江等地區(qū)提供建站服務(wù)。全流程定制設(shè)計(jì),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務(wù)

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

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

1、我們的主鍵基本上都采用共的是Sequence,沒有采用自動(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ù)類型不支持,部分函數(shù)沒有。

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

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

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

條件in中的數(shù)據(jù)有限制,否則ORA-01795: 列表中的最大表達(dá)式數(shù)為 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中不能使用,需要把a(bǔ)s去掉


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、最大的問(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)為日期類型。

在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這樣沒有時(shí)間的日期,但在Oracle中好像不行,也導(dǎo)致了很多問(wèn)題。

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

當(dāng)前名稱:DB2數(shù)據(jù)庫(kù)切換為oracle數(shù)據(jù)庫(kù)的示例分析
文章鏈接:http://jinyejixie.com/article6/pgscig.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營(yíng)銷型網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站建設(shè)網(wǎng)站收錄、用戶體驗(yàn)、做網(wǎng)站網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)
婺源县| 凭祥市| 普陀区| 河间市| 醴陵市| 醴陵市| 依安县| 洛扎县| 绥德县| 珠海市| 东城区| 贵南县| 仙游县| 裕民县| 松原市| 阿城市| 鹤壁市| 华坪县| 梅河口市| 靖边县| 澎湖县| 明溪县| 建德市| 慈利县| 叙永县| 临泽县| 房山区| 博乐市| 吴忠市| 文山县| 灵台县| 岳阳县| 大余县| 射阳县| 靖远县| 沙洋县| 昌邑市| 如东县| 基隆市| 绵阳市| 梅河口市|