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

cyt

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

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

    不知道為什么,還望賜教  回復  更多評論   
  • # re: 補充一個OCI的問題
    兄弟幫忙看看,多謝
    Posted @ 2013-05-27 10:51
    兄弟,請教下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í)行這條語句的時候就報錯:
    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>
            欧美国产亚洲精品久久久8v| 在线观看国产日韩| 亚洲欧美另类中文字幕| 亚洲精品永久免费| 亚洲日本欧美在线| 亚洲高清成人| 亚洲欧洲日本mm| 亚洲美女区一区| 亚洲午夜免费视频| 欧美在线不卡| 久久亚洲综合| 久久这里有精品15一区二区三区| 久久人体大胆视频| 免费日韩精品中文字幕视频在线| 老牛嫩草一区二区三区日本| 欧美国产先锋| 国产精品日韩专区| 禁久久精品乱码| 一本色道久久综合狠狠躁的推荐| 亚洲午夜精品视频| 久久噜噜亚洲综合| 亚洲精品日产精品乱码不卡| 亚洲欧美日韩国产一区| 午夜精品久久久久| 久久影院午夜论| 亚洲激情国产精品| 亚洲欧美国产另类| 欧美bbbxxxxx| 国产精品一区在线观看| 韩日在线一区| 亚洲一级二级在线| 免费日韩精品中文字幕视频在线| 亚洲欧洲日产国产网站| 欧美主播一区二区三区| 欧美日韩国产一区二区| 激情懂色av一区av二区av| 日韩小视频在线观看| 久久精品人人做人人爽| 99热在这里有精品免费| 麻豆精品视频在线观看| 国产三区精品| 亚洲性图久久| 亚洲激情电影在线| 久久人人97超碰国产公开结果 | 亚洲三级视频在线观看| 久久激情视频免费观看| 一级成人国产| 欧美激情91| 亚洲国产精品久久久久秋霞蜜臀 | 亚洲一区二区欧美| 欧美高清日韩| 久久综合999| 韩国av一区二区三区| 先锋影音久久久| 一区二区三区高清不卡| 欧美大片va欧美在线播放| 在线成人h网| 久久亚洲私人国产精品va媚药| 在线一区二区三区做爰视频网站| 欧美精品免费视频| 日韩午夜在线电影| 亚洲日本va午夜在线电影| 蜜桃av久久久亚洲精品| 一区在线视频观看| 久久天堂精品| 久久嫩草精品久久久精品| 一本大道久久a久久精品综合| 欧美日韩亚洲一区在线观看| 国产手机视频精品| 久久精品亚洲热| 先锋影院在线亚洲| 国内不卡一区二区三区| 久久久久久91香蕉国产| 久久精品日韩欧美| **网站欧美大片在线观看| 男女激情久久| 欧美高清在线一区二区| 夜夜爽www精品| 在线视频亚洲| 国产亚洲欧洲| 欧美激情欧美狂野欧美精品| 欧美丰满少妇xxxbbb| 亚洲视频在线观看| 小黄鸭精品aⅴ导航网站入口| 韩国一区电影| 亚洲国产精品久久人人爱蜜臀 | 亚洲香蕉网站| 国产亚洲福利社区一区| 久久久久久网| 欧美人成网站| 欧美专区在线观看| 美女视频网站黄色亚洲| 99精品国产一区二区青青牛奶| 99视频有精品| 狠狠综合久久av一区二区小说| 亚洲成人在线网| 国产精品羞羞答答xxdd| 欧美大香线蕉线伊人久久国产精品| 欧美激情一区二区三区不卡| 亚洲综合视频在线| 久久三级福利| 午夜精品偷拍| 欧美高清在线播放| 久久久青草青青国产亚洲免观| 欧美电影在线观看完整版| 午夜久久99| 欧美区亚洲区| 欧美激情在线狂野欧美精品| 国产精品女人网站| 亚洲人成在线播放网站岛国| 国产亚洲福利| 亚洲无亚洲人成网站77777| 亚洲国产综合视频在线观看| 亚洲夜间福利| 欧美高清在线| 久久免费视频一区| 国产精品久久久久aaaa九色| 欧美sm视频| 国产真实久久| 亚洲一区二区精品| 亚洲精品一线二线三线无人区| 小黄鸭精品aⅴ导航网站入口| 一区二区欧美精品| 欧美不卡视频一区发布| 久久久噜噜噜久久久| 国产精品久久久久久久午夜| 91久久精品日日躁夜夜躁欧美| 国产在线精品自拍| 欧美精品一区视频| 欧美精品一区二区三区在线播放| 久久琪琪电影院| 国产精品视频| 一卡二卡3卡四卡高清精品视频 | 国产日韩欧美二区| 亚洲一区二区三区精品在线观看| 洋洋av久久久久久久一区| 久久天天躁狠狠躁夜夜爽蜜月| 欧美一站二站| 国产婷婷一区二区| 亚洲欧美日本伦理| 欧美在线免费视频| 国产九九视频一区二区三区| 中日韩美女免费视频网址在线观看| 野花国产精品入口| 欧美日韩国产a| 一本色道久久精品| 亚洲欧美中文字幕| 国产一区二区激情| 久久久久久9999| 欧美国产精品va在线观看| 亚洲国产成人在线播放| 欧美成人综合一区| 亚洲精品美女在线观看播放| 日韩视频三区| 欧美午夜无遮挡| 午夜在线视频观看日韩17c| 久久综合网色—综合色88| 在线观看亚洲一区| 欧美欧美在线| 午夜在线视频观看日韩17c| 久久天堂国产精品| 日韩视频免费看| 国产美女扒开尿口久久久| 欧美在线1区| 亚洲激情在线播放| 欧美一级精品大片| 亚洲黄色免费| 日韩视频永久免费| 亚洲夜间福利| 国产真实乱偷精品视频免| 欧美成人三级在线| 亚洲欧美国产精品桃花| 欧美高清一区| 亚洲欧美日韩国产另类专区| 韩国欧美一区| 欧美午夜一区| 蜜臀av性久久久久蜜臀aⅴ| 亚洲精品极品| 久久青草久久| 亚洲一区二区三区视频| 一区二区三区自拍| 欧美午夜免费电影| 蜜臀久久久99精品久久久久久| 亚洲视频一二三| 亚洲福利一区| 久久久久久久国产| 一区二区精品在线观看| 黄色精品一二区| 国产精品久久国产精品99gif| 久久免费黄色| 香蕉久久夜色精品| 日韩视频在线观看国产| 欧美 日韩 国产一区二区在线视频| 亚洲在线观看视频网站| 亚洲国产日韩欧美在线图片| 国产午夜一区二区三区| 国产精品高清在线| 欧美日韩在线视频一区二区| 久久久亚洲国产美女国产盗摄| 一二三区精品福利视频|