SQL優化常用方法18

2021-09-22 19:06:13 字數 363 閱讀 3007

用exists替代in

在許多基於基礎表的查詢中,為了滿足乙個條件,往往需要對另乙個表進行聯接.在這種情況下, 使用exists(或not exists)通常將提高查詢的效率. 低效:

select * from emp (基礎表)

where empno > 0 and deptno in (select deptno from dept where loc = 『melb')

高效: select * from emp (基礎表)

where empno > 0 and exists (select 『x' from dept where dept.deptno = emp.deptno and loc = 『melb')

SQL優化常用方法38

避免在索引列上使用is null和is not null 避免在索引中使用任何可以為空的列,oracle將無法使用該索引 對於單列索引,如果列包含空值,索引中將不存在此記錄.對於復合索引,如果每個列都為空,索引中同樣不存在此記錄.如果至少有乙個列不為空,則記錄存在於索引中 舉例 如果唯一性索引建立在...

SQL優化常用方法36

用union替換or 適用於索引列 通常情況下,用union替換where子句中的or將會起到較好的效果.對索引列使用or將造成全表掃瞄.注意,以上規則只針對多個索引列有效.如果有column沒有被索引,查詢效率可能會因為你沒有選擇or而降低.在下面的例子中,loc id 和region上都建有索引...

SQL優化常用方法5

where子句中的連線順序 oracle採用自下而上的順序解析where子句,根據這個原理,表之間的連線必須寫在其他where條件之前,那些可以過濾掉最大數量記錄的條件必須寫在where子句的末尾.例如 低效,執行時間156.3秒 select from emp e where sal 50000 ...