Oracle数据库Where条件执行顺序
来源:互联网 发布:c语言可视化软件 编辑:程序博客网 时间:2024/05/09 06:23
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 WHERE条件执行顺序
- Oracle WHERE条件执行顺序
- Oracle数据库Where条件执行顺序 及Where子句的条件顺序对性能的影响
- Oracle数据库Where条件执行顺序 及Where子句的条件顺序对性能的影响
- Oracle数据库Where条件执行顺序 及Where子句的条件顺序对性能的影响
- Oracle数据库中的Where条件执行顺序是从后往前的?
- ORACLE中where部分条件执行顺序测试
- Oracle中的where部分的各个条件的执行顺序(右->左)
- Oracle中的where部分的各个条件的执行顺序(右->左)
- Oracle中的where部分的各个条件的执行顺序(右->左)
- [SqlServer] 性能优化实战-join与where条件执行顺序
- where条件的顺序是否影响mysql的执行效率
- Oracle数据库-where, group by, having, order by语句的执行顺序
- Oracle数据库-where, group by, having, order by语句的执行顺序
- Oracle数据库-where, group by, having, order by语句的执行顺序
- 各数据库SQL语句where条件解析顺序
- ORACLE几个过滤条件的执行顺序
- 第一次使用flash
- oracle lob 简单介绍
- TheadLocal 简明解释
- asp.net javascript回车键事件http://hi.baidu.com/xuexiang516168/blog/item/90f2bc4bc316372908f7eff4.html
- 用C#实现中文验证码
- Oracle数据库Where条件执行顺序
- InfoQ中文站总编辑推荐《软件设计精要与模式(第2版)》
- 相关评论
- 1.CheckBoxList js(http://hi.baidu.com/xuexiang516168/blog/item/bf772a324be85049ac4b5f3e.html)
- 把XMLDocument转换成xml字符串
- 用C#实现中文验证码
- NULL Comparision
- Windows系统中使用的批处理参数
- 数据库设计--ER图