SQL语句优化规律总结(ORACLE)
1、FROM: ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,因此FROM子句中写在最后的表(基础表 driving table)将被最先处理. 在FROM子句中包含多个表的情况下,你必须选择记录条数最少的表作为基础表(放在where的最后) 。如果有3个以上的表连接查询, 那就需要选择交叉表(intersection table)作为基础表, 交叉表是指那个被其他表所引用的表.
2、WHERE: ORACLE采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾。
3、在where子句中使用is null或is not null的语句优化器是不允许使用索引的,尽量不用。
4、少使用或不使用NOT。
5、如果通配符(%)在搜寻词首出现, Oracle系统不使用此列做索引。在很多情况下可能无法避免这种情况,但是一定要心中有底,通配符如此使用会降低查询速度。然而当通配符出现在字符串其他位置时,优化器就能利用索引。在下面的查询中索引得到了使用
select * from employee where last_name like 'c%';
6、 SELECT子句中避免使用 ‘ * ‘
7、避免在索引列上使用计算.如(WHERE SAL > 25000/12)
8、任何在Order by语句的非索引项或者有计算表达式都将降低查询速度。
9、关于IN、exists和DISTINCT
第一种格式是使用IN操作符:
... where column in(select * from ... where ...);
第二种格式是使用EXIST操作符:
... where exists (select 'X' from ...where ...);
第二种格式要远比第一种格式的效率高。
通常来说 , 采用表连接(emp.depart_cod=depart.depart_code)的方式比EXISTS更有效率
所以:连接>exists>IN。
用EXISTS替换DISTINCT
当提交一个包含一对多表信息(比如部门表和雇员表)的查询时,避免在SELECT子句中使用DISTINCT. 一般可以考虑用EXIST替换
低效:
SELECT DISTINCT DEPT_NO,DEPT_NAME
FROM DEPT D,EMP E
WHERE D.DEPT_NO = E.DEPT_NO
本内容试读结束,登录后可阅读更多
下载后可阅读完整内容,剩余2页未读,立即下载