青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

cyt

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

posted on 2007-03-30 00:00 cyt 閱讀(2411) 評論(5)  編輯 收藏 引用 所屬分類: Work
Comments
  • # re: 補充一個OCI的問題
    你好!請教個問題
    Posted @ 2007-06-15 09:04
    你好!
    你好, 看了你的一些文章感覺你好厲害得說!
    我不是專門研究程序的人,
    可現在我有點小困難,希望你幫忙解決 以下
    你的一片文章里說:
    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"
    ……
    我運行程序時候就缺少singalslot.h這個文件,一直在尋找singalslot.h這個頭文件,你能幫忙寫給我嗎?
    我的QQ346183499,全天再線
    謝謝了!
      回復  更多評論   
  • # re: 補充一個OCI的問題
    cyt
    Posted @ 2007-09-17 13:01
    Sorry長久沒有上來,所以沒有看到你的問題。
    這個signalslot.h是以前我自己研究練習寫的,沒有發布過,現在一下子也找不到在哪里。估計你的情況是需要的是一個第三方公開的那種類庫吧。估計這幾個對你有幫助:
    http://www.codeproject.com/cpp/ElmueSignalsandSlots.asp?df=100&forumid=38296&exp=0&select=1762527
    http://sigslot.sourceforge.net/
      回復  更多評論   
  • # re: 補充一個OCI的問題
    hongtium
    Posted @ 2007-10-10 13:52
    這個問題不是OCI才有的,Java的JDBC一樣。
    原因在于,用接口方式寫入的綁定變量,形如 "where xdate<? ", OCI或者JDBC調用產生的內部執行計劃都會把變量自動變成"where xdate<to_timestamp(?) " 形式。所以,如果xdate定義為date類型,則因為精度不匹配,oracle執行計劃將放棄對xdate的索引。
    解決就是把xdate定義成oracle的timestamp類型,或者把sql改成xdate<to_date(...)形式。
    至于oracle因為日期精度不匹配就不使用索引,可能是oracle的“過度安全”考慮。 原因大概是oracle的date/timestamp存儲結構不同。
      回復  更多評論   
  • # re: 補充一個OCI的問題
    canyon
    Posted @ 2008-06-14 13:34
    請教一個問題, 我使用SQLT_DAT綁定變量后使用7個字節的unsigned char將日期記入數據的DATE類型字段, 之后使用select *查詢可以看到日志,但是使用select to_char將其轉換成字符串確傳回的是0000-0-0

    不知道為什么,還望賜教  回復  更多評論   
  • # re: 補充一個OCI的問題
    兄弟幫忙看看,多謝
    Posted @ 2013-05-27 10:51
    兄弟,請教下occi如何綁定參數為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);

    然后執行這條語句的時候就報錯:
    ORA-01465: invalid hex number

    我的qq:2212099931  回復  更多評論   
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美天天视频| 国产精品久久毛片a| 亚洲国产精品成人精品| 亚洲美女av网站| 亚洲精选国产| 亚洲精选视频免费看| 欧美黄免费看| 欧美一级片久久久久久久| 久久精品国产亚洲高清剧情介绍| 国产免费成人在线视频| 亚洲一区免费视频| 久久亚洲精品中文字幕冲田杏梨| 一区二区三区无毛| 欧美日本免费| 久久精品论坛| 亚洲欧美日韩第一区| 亚洲高清免费视频| 亚洲欧洲日产国产综合网| 国产精品久久久久久久浪潮网站| 久久黄色网页| 在线亚洲激情| 99热免费精品在线观看| 久久天天躁狠狠躁夜夜爽蜜月 | 欧美一区二区私人影院日本| 乱人伦精品视频在线观看| 一区二区三区免费在线观看| 国外成人网址| 国产精品igao视频网网址不卡日韩| 久久久久五月天| 亚洲欧美在线播放| 欧美激情亚洲综合一区| 久久视频国产精品免费视频在线| 亚洲视频第一页| 一本一道久久综合狠狠老精东影业 | 欧美色网在线| 久久久精品国产免大香伊 | 国产亚洲午夜| 欧美三日本三级少妇三2023| 欧美成人dvd在线视频| 久热精品视频| 美女免费视频一区| 能在线观看的日韩av| 欧美日韩国产综合在线| 国产精品女主播一区二区三区| 国产精品久久国产三级国电话系列| 欧美日韩国产小视频在线观看| 欧美精品一区二区三区在线看午夜| 欧美国产三级| 欧美日韩在线播放一区| 激情综合色综合久久| 亚洲电影免费观看高清完整版在线观看| 激情欧美一区二区三区在线观看 | 国产一区再线| 国产一区二区剧情av在线| 在线日韩欧美| 亚洲一区久久久| 美女国内精品自产拍在线播放| 亚洲第一免费播放区| 亚洲精品免费一二三区| 亚洲午夜精品国产| 久久在线播放| 国产麻豆午夜三级精品| 在线国产欧美| 亚洲欧美日韩精品综合在线观看 | 久久精品论坛| 欧美午夜一区二区| 在线观看91精品国产入口| 亚洲毛片播放| 免费91麻豆精品国产自产在线观看| 亚洲美女区一区| 美女性感视频久久久| 国产精品国码视频| 亚洲精品欧美精品| 久久国产精品久久久| 日韩午夜三级在线| 一区二区视频在线观看| 亚洲欧美日本视频在线观看| 日韩视频在线观看国产| 欧美久久电影| 亚洲精品综合| 亚洲人成人一区二区三区| 亚洲靠逼com| 欧美88av| 精品9999| 亚洲电影免费观看高清| 乱码第一页成人| 最新亚洲一区| 老司机一区二区三区| 久久久久国产成人精品亚洲午夜| 精品51国产黑色丝袜高跟鞋| 老司机亚洲精品| 欧美一区二区三区免费大片| 加勒比av一区二区| 欧美成人综合网站| 欧美日韩二区三区| 亚洲综合色丁香婷婷六月图片| 午夜免费久久久久| 在线免费高清一区二区三区| 亚洲精品老司机| 国产亚洲va综合人人澡精品| 久久精品夜色噜噜亚洲aⅴ| 久久综合久久88| 亚洲一级二级在线| 亚洲一区三区在线观看| 在线免费观看一区二区三区| 日韩视频免费观看| 亚洲国产裸拍裸体视频在线观看乱了中文 | 国产一区视频观看| 99视频精品| 亚洲激情电影中文字幕| 久久久午夜精品| 亚洲一区二区三区精品动漫| 亚洲国产经典视频| 亚洲国产福利在线| 亚洲黄色一区二区三区| 国产香蕉久久精品综合网| 国产精品影片在线观看| 在线观看日韩av电影| 在线日韩中文字幕| 日韩图片一区| 亚洲一级影院| 欧美尤物一区| 午夜精品成人在线| 美女福利精品视频| 亚洲色在线视频| 亚洲欧美电影在线观看| 日韩亚洲在线观看| 午夜精品视频在线观看一区二区| 久久综合伊人77777蜜臀| 欧美日韩在线第一页| 国产女主播一区| 亚洲国产精品成人| 夜夜狂射影院欧美极品| 狼狼综合久久久久综合网 | 欧美视频在线看| 亚洲综合导航| 一区二区三区国产盗摄| 久久久国产一区二区三区| 国产日韩欧美三区| 狂野欧美激情性xxxx| 亚洲综合清纯丝袜自拍| 欧美性jizz18性欧美| 亚洲欧美日韩综合| 久久精品人人做人人综合| 久久久青草婷婷精品综合日韩| 国内精品久久久久影院优| 男女激情视频一区| 亚洲国产精品ⅴa在线观看 | 乱中年女人伦av一区二区| 中文网丁香综合网| 日韩午夜精品视频| 亚洲精品午夜精品| 美国成人直播| 亚洲人精品午夜| 国产综合久久久久久| 午夜日韩在线观看| 午夜老司机精品| 亚洲永久视频| 国产亚洲一区在线播放| 午夜精品在线看| 欧美www在线| 午夜精品久久久久久久久| 性欧美长视频| 在线观看日韩| 欧美视频二区36p| 久久精品国产在热久久| 亚洲精选大片| 欧美一区二区成人6969| 亚洲免费观看在线视频| 日韩视频专区| 国产精品二区二区三区| 99re这里只有精品6| 99视频在线观看一区三区| 一本色道久久综合一区| 亚洲高清久久久| 欧美日韩专区在线| 欧美一区二区日韩| 久久精品国产欧美激情| 欧美精品日韩| 久久久久青草大香线综合精品| 国产精品久久精品日日| av成人天堂| 在线一区二区三区做爰视频网站| 久久亚洲私人国产精品va| 亚洲国产精品va在线看黑人| 欧美一级艳片视频免费观看| 一区二区三区欧美激情| 欧美亚男人的天堂| 亚洲一区二区三区高清不卡| 免费精品视频| 欧美国产乱视频| 亚洲欧美在线免费观看| 欧美成人亚洲成人| 欧美刺激午夜性久久久久久久| 亚洲视频免费观看| 在线观看欧美一区| 一区二区三区欧美在线观看| 欧美性猛片xxxx免费看久爱| 欧美在线不卡| 欧美日韩一区二区免费在线观看|