• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            cyt

            前幾天客戶投訴我們提供的一個(gè)訪問Oracle的程序,說運(yùn)行太慢了,半天都沒有處理完數(shù)據(jù)。
            客戶數(shù)據(jù)也就幾十萬條,也不是什么海量數(shù)據(jù),究竟什么原因呢。而且奇怪的是我們提供的其它類似的程序訪問同一張數(shù)據(jù)表卻沒有任何的問題。
            經(jīng)過多次反復(fù)寫測(cè)試程序,嘗試各種的條件,最后發(fā)現(xiàn)原來是其中一條update語句執(zhí)行很慢,要2秒鐘才更新一條。而這條update語句的where部分有兩個(gè)條件,一個(gè)是整數(shù)的比較條件,一個(gè)是日期的比較條件。當(dāng)然很容易就可以通過測(cè)試排除了整數(shù)條件導(dǎo)致慢的可能性。剩下的原因就是日期比較條件導(dǎo)致慢了。
            說得也奇怪,日期條件是通過param的方式傳入?yún)?shù)的,執(zhí)行很慢。但測(cè)試的時(shí)候如果把日期條件展開,把日期條件變成SQL的一部分,那就執(zhí)行很快了。先不論為什么這么奇怪,要知道Oracle SQL語句的日期條件不是一般的麻煩,都要經(jīng)過TO_DATE/TO_CHAR糊弄來糊弄去,SQL語句跟其他的數(shù)據(jù)庫不一樣,程序就失去通用性了。一定是自己調(diào)用OCI的時(shí)候犯了什么糊涂錯(cuò)誤了。
            最后還是發(fā)現(xiàn)有一個(gè)不妥當(dāng)?shù)牡胤剑簲?shù)據(jù)庫字段類型是DATE,而我用OCI綁定param的時(shí)候,用的卻是SQLT_TIMESTAMP。原因是我想偷懶,希望用OraDateStruct就解決OCI的日期類型。于是我嘗試用回SQLT_DAT,自己“笨笨的”把時(shí)間轉(zhuǎn)換為OCI所能辨認(rèn)的7個(gè)byte的數(shù)組,然后運(yùn)行程序。速度太快了,一下子就執(zhí)行完了。
            其實(shí)不明白的是,Oracle發(fā)現(xiàn)類型不匹配,要不就報(bào)錯(cuò);要不就把條件變?yōu)橄嗳莸臄?shù)據(jù)進(jìn)行查詢。但是現(xiàn)在從現(xiàn)象看來,Oracle像是把所有保存的數(shù)據(jù)逐個(gè)轉(zhuǎn)換成為與條件相容的類型進(jìn)行判斷,而不是轉(zhuǎn)換條件的類型。所以每次update都變成了遍歷所有的數(shù)據(jù)。難道是存在DBA可以調(diào)整的優(yōu)化策略??不明白,不明白……

            posted on 2007-03-30 00:00 cyt 閱讀(2358) 評(píng)論(5)  編輯 收藏 引用 所屬分類: Work
            Comments
            • # re: 補(bǔ)充一個(gè)OCI的問題
              你好!請(qǐng)教個(gè)問題
              Posted @ 2007-06-15 09:04
              你好!
              你好, 看了你的一些文章感覺你好厲害得說!
              我不是專門研究程序的人,
              可現(xiàn)在我有點(diǎn)小困難,希望你幫忙解決 以下
              你的一片文章里說:
              singalslot.h里面就定義:
              #define TEMPLATE_ARGS typename A1
              #define FUNC_ARGS A1 a1
              #define SLOTBASENAME slot1base
              #include "signalslot.imp"

              #define TEMPLATE_ARGS typename A1,typename A2
              #define FUNC_ARGS A1 a1, A2 a2
              #define SLOTBASENAME slot2base
              #include "signalslot.imp"
              ……
              我運(yùn)行程序時(shí)候就缺少singalslot.h這個(gè)文件,一直在尋找singalslot.h這個(gè)頭文件,你能幫忙寫給我嗎?
              我的QQ346183499,全天再線
              謝謝了!
                回復(fù)  更多評(píng)論   
            • # re: 補(bǔ)充一個(gè)OCI的問題
              cyt
              Posted @ 2007-09-17 13:01
              Sorry長(zhǎng)久沒有上來,所以沒有看到你的問題。
              這個(gè)signalslot.h是以前我自己研究練習(xí)寫的,沒有發(fā)布過,現(xiàn)在一下子也找不到在哪里。估計(jì)你的情況是需要的是一個(gè)第三方公開的那種類庫吧。估計(jì)這幾個(gè)對(duì)你有幫助:
              http://www.codeproject.com/cpp/ElmueSignalsandSlots.asp?df=100&forumid=38296&exp=0&select=1762527
              http://sigslot.sourceforge.net/
                回復(fù)  更多評(píng)論   
            • # re: 補(bǔ)充一個(gè)OCI的問題
              hongtium
              Posted @ 2007-10-10 13:52
              這個(gè)問題不是OCI才有的,Java的JDBC一樣。
              原因在于,用接口方式寫入的綁定變量,形如 "where xdate<? ", OCI或者JDBC調(diào)用產(chǎn)生的內(nèi)部執(zhí)行計(jì)劃都會(huì)把變量自動(dòng)變成"where xdate<to_timestamp(?) " 形式。所以,如果xdate定義為date類型,則因?yàn)榫炔黄ヅ洌琽racle執(zhí)行計(jì)劃將放棄對(duì)xdate的索引。
              解決就是把xdate定義成oracle的timestamp類型,或者把sql改成xdate<to_date(...)形式。
              至于oracle因?yàn)槿掌诰炔黄ヅ渚筒皇褂盟饕?,可能是oracle的“過度安全”考慮。 原因大概是oracle的date/timestamp存儲(chǔ)結(jié)構(gòu)不同。
                回復(fù)  更多評(píng)論   
            • # re: 補(bǔ)充一個(gè)OCI的問題
              canyon
              Posted @ 2008-06-14 13:34
              請(qǐng)教一個(gè)問題, 我使用SQLT_DAT綁定變量后使用7個(gè)字節(jié)的unsigned char將日期記入數(shù)據(jù)的DATE類型字段, 之后使用select *查詢可以看到日志,但是使用select to_char將其轉(zhuǎn)換成字符串確傳回的是0000-0-0

              不知道為什么,還望賜教  回復(fù)  更多評(píng)論   
            • # re: 補(bǔ)充一個(gè)OCI的問題
              兄弟幫忙看看,多謝
              Posted @ 2013-05-27 10:51
              兄弟,請(qǐng)教下occi如何綁定參數(shù)為date類型,我這邊代碼如下:

              sql語句是:
              std::string sql = "INSERT INTO tbl_test(myid, myvc,myblob,mydt,mycblob)
              VALUES(111,'abc','blob',:a,'abc')";
              m_Command->setSql(sql);

              bool result = false;
              oracle::occi::Date d(m_pOwner->GetOracleEnvironment());
              d.setDate(Data.wYear, Data.wMonth, Data.wDay, Data.wHour, Data.wMinute, Data.wSecond);
              m_Command->setDate(index, d);

              然后執(zhí)行這條語句的時(shí)候就報(bào)錯(cuò):
              ORA-01465: invalid hex number

              我的qq:2212099931  回復(fù)  更多評(píng)論   
             
            久久精品国产一区二区三区不卡| 久久亚洲AV成人无码电影| 青青青青久久精品国产h| 国产免费久久精品99久久| 久久久久无码精品| 久久久国产乱子伦精品作者| 欧美亚洲国产精品久久蜜芽| 亚洲国产成人乱码精品女人久久久不卡 | 无码专区久久综合久中文字幕 | 色婷婷久久久SWAG精品| 亚洲色婷婷综合久久| 色综合色天天久久婷婷基地| 久久久久99这里有精品10 | 久久婷婷五月综合成人D啪| 精品国产乱码久久久久久郑州公司 | 亚洲欧洲久久av| 久久er热视频在这里精品| 久久精品亚洲AV久久久无码| 99久久夜色精品国产网站| 久久久久久久久久久久中文字幕| 精品欧美一区二区三区久久久| 综合人妻久久一区二区精品| 久久久精品人妻无码专区不卡| 久久久av波多野一区二区| 久久精品国产亚洲AV不卡| 天堂无码久久综合东京热| 欧美777精品久久久久网| 国内精品久久人妻互换| 亚洲AV无码久久精品蜜桃| 亚洲国产日韩综合久久精品| 久久久久亚洲精品中文字幕| 久久精品这里热有精品| 国产精品18久久久久久vr| 久久丫精品国产亚洲av不卡| 色欲av伊人久久大香线蕉影院| 久久久久久久97| 久久久久久久久久久久中文字幕 | 精品久久人人做人人爽综合| 久久综合狠狠色综合伊人| 色综合久久88色综合天天| 88久久精品无码一区二区毛片 |