打印本文 打印本文 关闭窗口 关闭窗口
SQL语句优化技术分析
作者:武汉SEO闵涛  文章来源:敏韬网  点击数4822  更新时间:2007/11/14 12:58:34  文章录入:mintao  责任编辑:mintao
的索引进行两个范围的查询,性能肯定大大提高。

 

UNION操作符

UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果。实际大部分应用中是不会产生重复的记录,最常见的是过程表与历史表UNION。如:

select * from gc_dfys

union

select * from ls_jg_dfys

这个SQL在运行时先取出两个表的结果,再用排序空间进行排序删除重复的记录,最后返回结果集,如果表数据量大的话可能会导致用磁盘进行排序。

推荐方案:采用UNION ALL操作符替代UNION,因为UNION ALL操作只是简单的将两个结果合并后就返回。

select * from gc_dfys

union all

select * from ls_jg_dfys

 

SQL书写的影响

同一功能同一性能不同写法SQL的影响

如一个SQLA程序员写的为

       Select * from zl_yhjbqk

B程序员写的为

       Select * from dlyx.zl_yhjbqk(带表所有者的前缀)

C程序员写的为

       Select * from DLYX.ZLYHJBQK(大写表名)

D程序员写的为

       Select *  from DLYX.ZLYHJBQK(中间多了空格)

 

以上四个SQLORACLE分析整理之后产生的结果及执行的时间是一样的,但是从ORACLE共享内存SGA的原理,可以得出ORACLE对每个SQL 都会对其进行一次分析,并且占用共享内存,如果将SQL的字符串及格式写得完全相同则ORACLE只会分析一次,共享内存也只会留下一次的分析结果,这不仅可以减少分析SQL

上一页  [1] [2] [3] [4] [5] [6]  下一页

打印本文 打印本文 关闭窗口 关闭窗口