度量快速开发平台-专业、快速的软件定制快开平台

标题: Oracle数据库Where条件执行顺序 [打印本页]

作者: 万望    时间: 2020-5-30 02:11
标题: Oracle数据库Where条件执行顺序

作为时常与数据库打交道的开发人员来说,写SQL必须必须要遵循以下几点的原则:

1.ORACLE采用自下而上的顺序解析WHERE子句

根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾.

例如:

(低效)

SELECT … FROM EMP E WHERE SAL > 50000 AND JOB = ‘MANAGER’ AND 25 < (SELECT COUNT(*) FROM EMP WHERE MGR=E.EMPNO);

(高效)

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条件执行顺序,大家好可以去了解更多的Oracle数据库语句条件,希望上文中介绍的内容对大家能够有所帮助。



作者: 万望    时间: 2020-5-30 02:13
严谨的语法才能写出执行效率更高的语句
作者: 陈晓龙    时间: 2020-5-30 16:23
万望 发表于 2015-12-31 02:13
严谨的语法才能写出执行效率更高的语句

是呢,楼主好智商!
作者: 张兴康    时间: 2020-5-30 16:26
一切为了提高效率
作者: 张兴康    时间: 2020-5-30 17:13
陈晓龙 发表于 2015-12-31 16:23
是呢,楼主好智商!



作者: 陈晓龙    时间: 2020-6-4 13:56
用* 确实效率低!
作者: 万望    时间: 2020-6-4 15:59
陈晓龙 发表于 2016-1-4 13:56
用* 确实效率低!


作者: 王爱东    时间: 2020-6-4 16:36
写sql现在就是要考虑到性能了。能写出性能好的sql,需要有扎实的基本功。




欢迎光临 度量快速开发平台-专业、快速的软件定制快开平台 (http://bbs.delit.cn/) Powered by Discuz! X3.2