轻松掌握Oracle数据库Where条件执行顺序Oracle认证考试

文章作者 100test 发表时间 2009:07:08 04:28:51
来源 100Test.Com百考试题网


  由于SQL优化起来比较复杂,并且还会受环境限制,在开发过程中,写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数据库中使用DBMS_PROFILER进行调优Oracle认证考试
Oracle数据库SQL语句性能调整的基本原则Oracle认证考试
详细讲解Oracle数据库10gRMAN的备份过程Oracle认证考试
数据库中判断一个字符串内是否含有中文Oracle认证考试
轻松掌握Oracle数据库Where条件执行顺序Oracle认证考试
Oracle数据库中为什么会产生回滚与前退Oracle认证考试
undo表空间暴长后如何才能取消自动扩展Oracle认证考试
通过几个步骤有效关闭Oracle死锁进程Oracle认证考试
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛