程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> Oracle SQL執行緩慢的原因分析

Oracle SQL執行緩慢的原因分析

編輯:Oracle數據庫基礎

以下的文章主要介紹的是Oracle SQL執行緩慢的分析,如果你是Oracle SQL執行方面的新手,你就可以通過以下的文章對Oracle SQL執行有一個更好的了解,以下就是文章的詳細內容的介紹。

Oracle SQL執行緩慢的分析

問題描述:

Oracle數據庫中一張表的數據已經2億多,而且此表創建了4個獨立的索引。由於業務需要,每天需分兩次向此表中插入300萬條記錄。由於數據量大,每次插入耗時3個小時以上,嚴重影響效率。因此,修改了系統的算法,將此表中只存儲當天新增記錄。

將此表truncate後,第二天執行對此表的update操作時,非常耗時。表中有2億多條數據的時候,此sql語句耗時59秒;表中有300萬條數據的時候,此Oracle SQL語句耗時幾個小時。咨詢DBA後,得出結論,需重建索引。重建後,6秒完成此操作。但第三天問題依然出現。DBA正在查找原因。難道每次truncate表,都需要重建索引?

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

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

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

重新生成統計數據調整後,整個操作耗時非常少。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved