我们要做到不但会写SQL,还要做到写出性能优良的SQL语句。
(1)选择最有效率的表名顺序(只在基于规则的优化器中有效):
Oracle的解析器按照从右到左的顺序处理FROM子句中的表名
,FROM子句中写在最后的表(基础表 driving
table)将被最先处理
,在FROM子句中包含多个表的情况下,您必须选择记录条数最少的表作为基础表。假如有3个以上的表连接查询,
那就需要选择交叉表(intersection table)作为基础表, 交叉表是指那个被其他表所引用的表。
(2)WHERE子句中的连接顺序:
Oracle采用自下而上的顺序解析WHERE子句
,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些能够过滤掉最大数量记录的条件必须写在WHERE子句的末尾
。
(3)SELECT子句中避免使用‘*’:
Oracle在解析的过程中, 会将‘*’依次转换成任何的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间。
(4)减少访问数据库的次数:
Oracle在内部执行了许多工作: 解析SQL语句, 估算索引的利用率, 绑定变量 , 读数据块等。
(5)在SQL*Plus , SQL*Forms和Pro*C中重新配置ARRAYSIZE参数, 能够增加每次数据库访问的检索数据量 ,建议值为200
。
(6)使用DECODE函数来减少处理时间:
使用DECODE函数能够避免重复扫描相同记录或重复连接相同的表
。
(7)整合简单,无关联的数据库访问:
假如您有几个简单的数据库查询语句,您能够把他们整合到一个查询中(即使他们之间没有关系)。
(8)删除重复记录:
最高效的删除重复记录方法 ( 因为使用了ROWID)例子:
DELETE FROM EMP E WHERE E.ROWID > (SELECT MIN(X.ROWID) FROM EMP X WHERE X.EMP_NO = E.EMP_NO);
(9)用TRUNCATE替代DELETE:
当删除表中的记录时,在通常情况下, 回滚段(rollback segments ) 用来存放能够被恢复的信息.
假如您没有COMMIT事务,ORACLE会将数据恢复到删除之前的状态(准确地说是恢复到执行删除命令之前的状况) 而当运用TRUNCATE时,
回滚段不再存放任何可被恢复的信息。当命令运行后,数据不能被恢复.因此很少的资源被调用,执行时间也会很短。(TRUNCATE只在删除全表适
用,TRUNCATE是DDL不是DML
)。
(10)尽量多使用COMMIT:
只要有可能,在程式中尽量多使用COMMIT, 这样程式的性能得到提高,需求也会因为COMMIT所释放的资源而减少
,COMMIT所释放的资源:
a. 回滚段上用于恢复数据的信息。
b. 被程式语句获得的锁。
c. redo log buffer 中的空间。
d. Oracle为管理上述3种资源中的内部花费。
(11)用Where子句替换HAVING子句:
避免使用HAVING子句,HAVING
只会在检索出任何记录之后才对结果集进行过滤。这个处理需要排序,总计等操作。假如能通过WHERE子句限制记录的数目,那就能减少这方面的开销。(非
oracle中)on、where、having这三个都能够加条件的子句中,on是最先执行,where次之,having最后
,因为on是先把不符合
条件的记录过滤后才进行统计,他就能够减少中间运算要处理的数据,按理说应该速度是最快的,where也应该比having快点的,因为他过滤数据后才进
行sum,在两个表联接时才用on的,所以在一个表的时候,就剩下where跟having比较了。在这单表查询统计的情况下,假如要过滤的条件没有涉及
到要计算字段,那他们的结果是相同的,只是where能够使用rushmore技术,而having就不能,在速度上后者要慢假如要涉及到计算的字段,就
表示在没计算之前,这个字段的值是不确定的,根据上篇写的工作流程,where的作用时间是在计算之前就完成的,而having就是在计算后才起作用的,
所以在这种情况下,两者的结果会不同。在多表联接查询时,on比where更早起作用。系统首先根据各个表之间的联接条件,把多个表合成一个临时表后,再
由where进行过滤,然后再计算,计算完后再由having进行过滤。由此可见,要想过滤条件起到正确的作用,首先要明白这个条件应该在什么时候起作
用,然后再决定放在那里。
(12)减少对表的查询:
在含有子查询的SQL语句中,要特别注意减少对表的查询。例子:
SELECT TAB_NAME FROM TABLES WHERE (TAB_NAME,DB_VER) = ( SELECTTAB_NAME,DB_VER FROM TAB_COLUMNS WHERE VERSION = 604)
(13)通过内部函数提高SQL效率:
复杂的SQL往往牺牲了执行效率。能够掌控上面的运用函数解决问题的方法在实际工作中是很有意义的。
(14)使用表的别名(Alias):
当在SQL语句中连接多个表时, 请使用表的别名并把别名前缀于每个Column上
。这样一来,就能够减少解析的时间并减少那些由Column歧义引起的语法错误。
(15)用EXISTS替代IN、用NOT EXISTS替代NOT IN:
在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下,使用EXISTS(或NOT
EXISTS)通常将提高查询的效率。在子查询中,NOT IN子句将执行一个内部的排序和合并。无论在哪种情况下,NOT IN都是最低效的
(因为他对子查询中的表执行了一个全表遍历)。为了避免使用NOT IN ,我们能够把他改写成外连接(Outer Joins)或NOT
EXISTS。
例子:
(高效)SELECT * FROM EMP (基础表) WHERE EMPNO > 0 AND EXISTS (SELECT
‘X' FROM DEPT WHERE DEPT.DEPTNO = EMP.DEPTNO AND LOC =
‘MELB')(低效)SELECT * FROM EMP (基础表) WHERE EMPNO > 0 AND DEPTNO
IN(SELECT DEPTNO FROM DEPT WHERE LOC = ‘MELB')
(16)识别‘低效执行’的SQL语句:
虽然现在各种关于SQL优化的图像化工具层出不穷,但是写出自己的SQL工具来解决问题始终是个最好的方法:
SELECT EXECUTIONS , DISK_READS, BUFFER_GETS,
ROUND((BUFFER_GETS-DISK_READS)/BUFFER_GETS,2) Hit_radio,
ROUND(DISK_READS/EXECUTIONS,2) Reads_per_run, SQL_TEXT FROM V$SQLAREA
WHERE EXECUTIONS>0 AND BUFFER_GETS > 0 AND
(BUFFER_GETS-DISK_READS)/BUFFER_GETS < 0.8 ORDER BY 4 DESC;
分享到:
相关推荐
在《CAD绘图技巧之提高效率篇.pdf》这一文件中,主要讨论了如何通过不同的技术手段和操作技巧,在使用CAD绘图软件时提高绘图效率。文件指出,随着计算机和网络技术的迅速发展,CAD软件在工程绘图领域的应用日益广泛...
提高写代码的效率(编程篇) 在编程领域中,提高写代码的效率是每个程序员必须面对的挑战。本文将总结如何提高代码的书写效率和练习方法。通过分析常见的编程错误和解决方法,我们可以总结出两大关键点:养成好的...
在第1部分“基础算法(提高篇)”中,作者深入探讨了数据结构与算法的基础知识,旨在帮助参赛者提升解决复杂问题的能力。这部分内容对于信息学竞赛的参与者,尤其是对数据点处理有需求的选手来说,是非常关键的学习...
2. **模块化和分层设计**:将复杂的问题分解为小的、可管理的部分是提高编程效率的一个重要策略。模块化可以让你专注于一个特定功能,而不是整个项目,这样可以减少错误并易于维护。同时,采用分层设计(如MVC模式)...
《1理念与思维(效率篇xy).pptx》这份财务管理类PPT文档,深入探讨了企业管理的核心理念,以及如何通过工业化的思维模式提高企业的运营效率,进而实现成本控制和利润最大化。 企业管理理念的重塑始于对基本经济模型...
富士通C手册是一系列详尽的编程指南,旨在帮助开发者深入理解和熟练运用富士通架构下的C语言。这份手册分为三个部分:基础篇、提高...无论是初学者还是专业人士,都应该认真研读,以提升自己的编程能力和项目实施效率。
这篇文章将介绍如何使用 GDI+ 的双缓冲技术来提高绘图效率。 GDI+ 的双缓冲技术可以简单地理解为将绘图操作缓存在内存中,然后将其快速地绘制到屏幕上,从而提高绘图效率。这种技术可以减少屏幕刷新的次数,并且...
《如何从管理层面提升业绩组织优化与运营效率篇》的讨论主要集中在如何通过管理策略和组织架构的调整来提高企业的业绩和运营效率。以下是对这个主题的详细阐述: 首先,营销组织优化是提升企业竞争力的关键。优化的...
《如何从管理层面提升业绩-组织优化与运营效率篇》的讨论主要集中在企业管理中的关键环节,特别是营销组织的优化和运营效率的提升。这涉及到企业的核心竞争力、员工积极性的激发以及适应市场变化的能力。 首先,...
本课件集合了基础篇与提高篇,旨在为学习者提供一个全面且深入的DSP知识框架,帮助初学者入门,并逐步提升至高级水平。 在基础篇中,首先会介绍基本的信号与系统理论,包括连续信号与离散信号的区别,线性时不变...
《地下车库优化停车效率》专篇讲解了如何提高地下车库的空间利用率,主要涉及停车场的设计、柱网布局、停车方式以及交通流线等多个方面。以下是基于PPT教案的主要知识点: 1. 地库停车效率定义:地库停车效率是指...
【标题】和【描述】提及的是九年级物理课程中关于机械效率的一个同步测试,主要针对2018学年新版苏科版教材。这个测试旨在提高学生对机械效率的理解和应用能力。 【部分内容】涉及的知识点包括: 1. **机械效率的...
提高篇》教学课件集合了多个IT领域的重要知识点,主要涵盖了基础算法、字符串算法、数据结构、图论、动态规划以及数论这六个核心部分。这些主题是计算机科学与信息技术学习中的基石,对于提升编程能力、解决复杂问题...
《信捷触摸屏用户手册提高篇之高级功能》是一份专...总之,《信捷触摸屏用户手册提高篇之高级功能》是提升用户技术水平的重要资料,通过深入学习,用户不仅可以提升个人技能,也能助力企业的自动化升级和生产效率提升。
本篇文章将深入探讨如何提高GDI绘图的性能和效率,并涉及到DirectDraw的相关技术。 首先,"基于MFC的DirectDraw高速图形绘制方法与应用.pdf"这篇文章可能会讨论如何利用Microsoft Foundation Class (MFC)库来整合...
本书全面、系统地讲解了Excel在日常工作中的应用,结构独具匠心,以应知应会的知识点为主线,以实际案例和应用技巧为主题,有助于职场人士解决实际工作中的问题,提高工作效率,培养Excel应用能力。本书附带1张光盘...
《地下车库优化停车效率专篇》的PPT学习教案详细探讨了如何提升地下车库的停车效率,这在现代城市规划和建筑设计中具有重要意义。停车效率指的是地下车库单位车位占用的面积,通过计算车库总面积除以总车辆数来得出...
这篇文章将深入探讨如何通过科学的方法和策略提升效率,让大脑更好地运作,实现事半功倍的效果。 首先,我们要理解大脑的工作机制。大脑是一个复杂的器官,它需要充足的休息、营养和适度的刺激来保持最佳状态。确保...
在编程领域,提高代码编写效率是每位开发者关注的重点。以下是一些关键的知识点和实践策略,旨在帮助提升编程效率: 首先,扎实的语法基础是关键。在初入软件行业时,由于对编程语言不熟悉,可能会频繁遇到语法错误...