Oracle WHERE条件执行顺序

sql优化比较复杂,且受环境限制,但开发过程中,写sql要遵循最起码的原则.如下:


   1.ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾.

例如:

Sql代码  <EMBED type=application/x-shockwave-flash pluginspage=http://www.macromedia.com/go/getflashplayer height=15 width=14 src=http://mtnt2008.iteye.com/javascripts/syntaxhighlighter/clipboard_new.swf allowscriptaccess="always" quality="high" flashvars="clipboard=%2F*%20%E4%BD%8E%E6%95%88%20*%2F%0A%0ASELECT%20%E2%80%A6%20FROM%20EMP%20E%20WHERE%20SAL%20%3E%2050000%20AND%20JOB%20%3D%20%E2%80%98MANAGER%E2%80%99%20AND%2025%20%3C%20(SELECT%20COUNT(*)%20FROM%20EMP%20WHERE%20MGR%3DE.EMPNO)%3B" wmode="transparent">  收藏代码
  1. /* 低效 */  
  2.   
  3. SELECT … FROM EMP E WHERE SAL > 50000 AND JOB = ‘MANAGER’ AND 25 < (SELECT COUNT(*) FROM EMP WHERE MGR=E.EMPNO);  

 

Sql代码  <EMBED type=application/x-shockwave-flash pluginspage=http://www.macromedia.com/go/getflashplayer height=15 width=14 src=http://mtnt2008.iteye.com/javascripts/syntaxhighlighter/clipboard_new.swf allowscriptaccess="always" quality="high" flashvars="clipboard=%2F*%20%E9%AB%98%E6%95%88%20*%2F%0A%0A%20%20%20%20SELECT%20%E2%80%A6%20FROM%20EMP%20E%20WHERE%2025%20%3C%20(SELECT%20COUNT(*)%20FROM%20EMP%20WHERE%20MGR%3DE.EMPNO)%20AND%20SAL%20%3E%2050000%20AND%20JOB%20%3D%20%E2%80%98MANAGER%E2%80%99%3B" wmode="transparent">  收藏代码
  1. /* 高效 */  
  2.   
  3.     SELECT … FROM EMP E WHERE 25 < (SELECT COUNT(*) FROM EMP WHERE MGR=E.EMPNO) AND SAL > 50000 AND JOB = ‘MANAGER’;  
 



2.SELECT子句中避免使用’*’

   当在SELECT子句中列出所有的COLUMN时,使用动态SQL列引用 ‘*’ 是一个方便的方法.可是,这是一个非常低效的方法. 实际上,ORACLE在解析的过程中, 会将’*’ 依次转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间.

3.   使用表的别名(Alias)

当在SQL语句中连接多个表时, 请使用表的别名并把别名前缀于每个Column上.这样一来,就可以减少解析的时间并减少那些由Column歧义引起的语法错误.

(Column歧义指的是由于SQL中不同的表具有相同的Column名,当SQL语句中出现这个Column时,SQL解析器无法判断这个Column的归属)


你可能感兴趣的:(Oracle WHERE条件执行顺序)