"ORACLE SQL性能优化:避免首位通配符%的like语句使用"

需积分: 9 0 下载量 160 浏览量 更新于2024-01-17 收藏 2.32MB PPT 举报
带通配符%的like语句是在Oracle SQL中进行性能优化时需要考虑的一个关键问题。在使用通配符%的情况下,如将通配符%放在搜索词的首位,Oracle系统将无法使用last_name的索引进行查询优化。这意味着查询速度会受到降低。然而,当通配符%出现在字符串的其他位置时,优化器可以利用索引来提高查询效率。 对于无法避免使用通配符%的情况,我们在优化查询的过程中必须有清晰的目标和底线。虽然这种使用方式会降低查询速度,但我们可以通过其他方式来优化查询。下面的查询示例中,索引得到了使用,从而提高了查询性能: ```sql select * from employee where last_name like 'c%'; ``` 除了在查询中使用通配符%进行搜索优化外,Oracle SQL性能优化还涉及到一系列内容。以下是一个内部培训班课程的概述,主要讨论了SQL语句执行的过程、Oracle优化器、表之间的关联、如何获取SQL执行计划以及如何分析执行计划等内容。通过逐步学习SQL优化的过程,我们可以逐渐掌握SQL优化的技巧。 本培训班的目录如下: 1. 优化基础知识:介绍了性能管理、性能问题、优化的方法、SQL优化机制、应用的调整等内容。 2. 性能调整综述:讨论了系统性能衡量指标,如系统响应时间和并发性,以及造成SQL性能差的两个主要原因。 3. 有效的应用设计:介绍了如何设计有效的应用程序,包括数据库设计、索引设计等。 4. SQL语句的处理过程:详细解释了SQL语句在Oracle中的处理过程,包括共享SQL区域、SQL语句处理的阶段、共享游标、SQL编码标准等。 5. Oracle优化器:介绍了Oracle优化器的基本原理和工作方式,以及如何使用优化器来提升SQL查询性能。 6. Oracle的执行计划:解释了执行计划的概念和重要性,以及如何获取和分析执行计划来识别潜在的性能问题。 7. 注意事项:总结了在进行SQL性能优化时需要注意的一些问题和技巧。 优化SQL性能需要从多个方面综合考虑,包括合适的索引设计、优化器的使用、执行计划的分析等。我们应该尽早开始优化工作,并设立合适的目标。在调整过程中,与相关人员进行合作,并及时处理可能发生的意外和变化。此外,根据80/20定律,我们应该集中优化那些影响性能的关键SQL语句,以获取最大的性能提升。 总之,带通配符%的like语句在Oracle SQL性能优化中需要进行注意和处理。尽管通配符%的不恰当使用会降低查询速度,但通过合理的索引设计和优化器的使用,我们可以提高查询性能。通过学习SQL优化的知识和技巧,我们可以更好地理解和应用Oracle SQL性能优化的方法。
125 浏览量
我们要做到不但会写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函数能够避免重复扫描相同记录或重复连接相同的表。