tbwshc

          Oracle SQL執行緩慢的原因以及解決方案

          以下的文章抓喲是對Oracle SQL執行緩慢的原因的分析,如果Oracle數據庫中的某張表的相關數據已是2億多時,同時此表也創建了相關的4個獨立的相關索引。由于業務方面的需要,每天需分兩次向此表中插入300萬條記錄。

           

          由于數據量大,每次插入耗時3個小時以上,嚴重影響效率。

          因此,修改了系統的算法,將此表中只存儲當天新增記錄。將此表truncate后,第二天執行對此表的update操作時,非常耗時。表中有2億多條數據的時候,此Oracle sql語句耗時59秒;表中有300萬條數據的時候,此Oracle sql語句耗時幾個小時。

          咨詢DBA后,得出結論,需重建索引。重建后,6秒完成此操作。但第三天問題依然出現。DBA正在查找原因。難道每次truncate表,都需要重建tb索引?

          對于這個問題,DBA也沒有給出合理的解釋,推測主要原因是Oracle復雜的查詢優化算法。

          最終,DBA給出的解決方案:


          1. truncate table ....  
          2. drop index.....  
          3. insert data .....  
          4. create index ...  
          5. analyze table table_name compute statistics;

           

          重新生成統計數據

          調整后,整個操作耗時非常少。 

          以上的相關內容就是對Oracle SQL執行緩慢的分析的介紹,望你能有所收獲。

           

          posted on 2012-06-30 22:46 chen11-1 閱讀(933) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           

          My Links

          Blog Stats

          常用鏈接

          留言簿(4)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          新聞檔案

          tbw淘寶商城-首頁

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 枞阳县| 盐边县| 顺昌县| 洛隆县| 洱源县| 灵丘县| 红原县| 西丰县| 宜都市| 礼泉县| 馆陶县| 连江县| 万载县| 洪江市| 黔江区| 大竹县| 娄底市| 河南省| 寿阳县| 武强县| 永济市| 祥云县| 淮阳县| 鄂尔多斯市| 喜德县| 峡江县| 福海县| 菏泽市| 阿克苏市| 西平县| 青海省| 南陵县| 林周县| 扬州市| 湛江市| 德阳市| 黄大仙区| 柳河县| 横峰县| 上犹县| 秦安县|