av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

Oracle中存儲過程和Sql語句的優(yōu)化重點

Oracle數據庫是功能性很好的數據庫管理系統(tǒng),至今為止在數據庫市場中仍占有主要份額,下文中將為大家講解Oracle中存儲過程和Sql語句的優(yōu)化重點 ,希望對大家能夠有所幫助。

創(chuàng)新互聯公司是一家專業(yè)提供殷都企業(yè)網站建設,專注與成都網站制作、成都網站設計、外貿營銷網站建設、html5、小程序制作等業(yè)務。10年已為殷都眾多企業(yè)、政府機構等服務。創(chuàng)新互聯專業(yè)網站制作公司優(yōu)惠進行中。

1.全表掃描和索引掃描

大數據量表盡量要避免全表掃描,全部掃描會按順序每條記錄掃描,對于>100萬數據表影響很大。

Oracle中通過RowID訪問數據是最快的方式

對字段進行函數轉換,或者前模糊查詢都會導致無法應用索引而進行全表掃描

對Oracle共享池和緩沖區(qū)中的Sql必須要大小寫都完全用上才能夠匹配上

2.順序問題

Oracle按照從右到左的順序對數據表進行解析。因此From最后面的表為基礎表,一般要選擇記錄數最少的表作為基礎表。

對于Where條件的順序,過濾到最大查詢記錄數量的條件必須寫在Where條件的結尾處。

Where條件中涉及到使用復雜函數判定的必須注意要寫到Where條件的最前面

3.索引方面

記錄數少的表保留有主鍵索引就可以了,不要再去建其它索引,全表掃描也很快

索引最好單獨建立表空間,必要時候對索引進行重建

必要時候可以使用函數索引,但不推薦使用

Oracle中的視圖也可以增加索引,但一般不推薦使用

Sql語句中大量使用函數時候會導致很多索引無法使用上,要針對具體問題分析

4.其它

避免使用Select ,因為系統(tǒng)需要去幫你將轉換為所有的列名,這個需要額外去查詢數據字典。

Count(1)和Count()差別不大。

多使用Decode函數來作簡單的代碼和名稱間的轉換,以減少表關聯

使用Truncate替代delete來刪除記錄,但Truncate數據不記錄日志,無法進行回滾

對于復雜的存儲過程可以多次提交的數據的要多分多次Commit,否則長事務對系統(tǒng)性能影響很大

Distinct和Having子句都是耗時操作,應該盡可能少使用

在不需要考慮重復記錄合并時候用Union All來代替Union

使用顯性游標而不使用隱性游標,特別是大數據量情況下隱性游標對性能影響很大

是否使用函數的問題

用直接的表關聯來代替Exist.用Exist或Not Exists來代理In。In進行子查詢效率很差。

5.SQL語句分析

通過SQLPLUS中的SET TRACE 功能對Sql語句的性能進行分析

通過Toad或PL/SQL Developer對語句的性能進行和索引的使用情況進行分析

對Oracle缺省的優(yōu)化不滿意可以強制使用Hint,但一般不推薦使用

對Flag等只存儲是或否信息的字段,一般不推薦建立索引。必要可以采用位圖索引

存在遞歸查詢情況如果關聯Table太多對性能會造成較大影響,往往推薦采用臨時表轉為分步驟操作提高性能

盡量使用表關聯查詢而不使用函數,但涉及類似于代碼表要重復關聯多次取數據問題時候又適合使用函數

上文中就Oracle中存儲過程和Sql語句的優(yōu)化重點作出了詳細的講解,希望大家都能夠從中有所收獲,這樣,在以后的工作中遇到類似問題就能夠輕松解決。


文章題目:Oracle中存儲過程和Sql語句的優(yōu)化重點
網站鏈接:http://uogjgqi.cn/article/djcisjg.html
掃二維碼與項目經理溝通

我們在微信上24小時期待你的聲音

解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯網交流