Oracle SQL性能优化40条,值得收藏(五)

简介: 之前有发布一些Mysql的性能优化方法,有些小伙伴想了解一下Oracle的性能优化有哪些,特地去找了一些比较全和实用的文章,这篇就是其中一篇。对Oracle性能优化感兴趣的不妨收藏一些,以备不时之需。(部分内容存在错别字和技术性错误,有改动)

32. 使用提示(Hints)

  • FULL hint 告诉ORACLE使用全表扫描的方式访问指定表。
  • ROWID hint 告诉ORACLE使用TABLE ACCESS BY ROWID的操作访问表。
  • CACHE hint 来告诉优化器把查询结果数据保留在SGA中。
  • INDEX Hint 告诉ORACLE使用基于索引的扫描方式。

其他的Oracle Hints

  • ALL_ROWS
  • FIRST_ROWS
  • RULE
  • USE_NL
  • USE_MERGE
  • USE_HASH 等等。

这是一个很有技巧性的工作。建议只针对特定的,少数的SQL进行hint的优化。


33. 几种不能使用索引的WHERE子句

(1)下面的例子中,‘!=’ 将不使用索引 ,索引只能告诉你什么存在于表中,而不能告诉你什么不存在于表中。


30.png


(2)下面的例子中,‘||’是字符连接函数。就象其他函数那样,停用了索引。

31.png


(3)下面的例子中,‘+’是数学函数。就象其他数学函数那样,停用了索引。


32.png

(4)下面的例子中,相同的索引列不能互相比较,这将会启用全表扫描。

33.png


34. 连接多个扫描

如果对一个列和一组有限的值进行比较,优化器可能执行多次扫描并对结果进行合并连接。

举例:

34.png

优化器可能将它转换成以下形式:

35.png

35. CBO下使用更具选择性的索引

  • 基于成本的优化器(CBO,Cost-Based Optimizer)对索引的选择性进行判断来决定索引的使用是否能提高效率。
  • 如果检索数据量超过30%的表中记录数,使用索引将没有显著的效率提高。
  • 在特定情况下,使用索引也许会比全表扫描慢。而通常情况下,使用索引比全表扫描要块几倍乃至几千倍!


36. 避免使用耗费资源的操作

  • 带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎执行耗费资源的排序(SORT)功能。DISTINCT需要一次排序操作,而其他的至少需要执行两次排序。
  • 通常,带有UNION,MINUS,INTERSECT的SQL语句都可以用其他方式重写。


37. 优化GROUP BY

提高GROUP BY语句的效率,可以通过将不需要的记录在GROUP BY之前过滤掉。

36.png

38. 使用日期

当使用日期时,需要注意如果有超过5位小数加到日期上,这个日期会进到下一天!

37.png

39. 使用显示游标(CURSORS)

使用隐式的游标,将会执行两次操作。第一次检索记录,第二次检查TOO MANY ROWS 这个exception。而显式游标不执行第二次操作。


40. 分离表和索引

  • 总是将你的表和索引建立在不同的表空间内(TABLESPACES)。
  • 决不要将不属于ORACLE内部系统的对象存放到SYSTEM表空间里。
  • 确保数据表空间和索引表空间置于不同的硬盘上。

好了,关于Oracle SQL优化的内容,这一篇应该满足常规大部分的应用优化要求。就先到这里了。


相关文章
|
1月前
|
SQL 缓存 监控
SQL性能提升指南:五大优化策略与十个实战案例
在数据库性能优化的世界里,SQL优化是提升查询效率的关键。一个高效的SQL查询可以显著减少数据库的负载,提高应用响应速度,甚至影响整个系统的稳定性和扩展性。本文将介绍SQL优化的五大步骤,并结合十个实战案例,为你提供一份详尽的性能提升指南。
48 0
|
2月前
|
监控 Oracle 关系型数据库
Oracle数据库性能优化
【10月更文挑战第16天】Oracle数据库性能优化是
39 1
|
3月前
|
存储 SQL 关系型数据库
【MySQL调优】如何进行MySQL调优?从参数、数据建模、索引、SQL语句等方向,三万字详细解读MySQL的性能优化方案(2024版)
MySQL调优主要分为三个步骤:监控报警、排查慢SQL、MySQL调优。 排查慢SQL:开启慢查询日志 、找出最慢的几条SQL、分析查询计划 。 MySQL调优: 基础优化:缓存优化、硬件优化、参数优化、定期清理垃圾、使用合适的存储引擎、读写分离、分库分表; 表设计优化:数据类型优化、冷热数据分表等。 索引优化:考虑索引失效的11个场景、遵循索引设计原则、连接查询优化、排序优化、深分页查询优化、覆盖索引、索引下推、用普通索引等。 SQL优化。
619 15
【MySQL调优】如何进行MySQL调优?从参数、数据建模、索引、SQL语句等方向,三万字详细解读MySQL的性能优化方案(2024版)
|
2月前
|
SQL 监控 Oracle
Oracle SQL性能优化全面指南
在数据库管理领域,Oracle SQL性能优化是确保数据库高效运行和数据查询速度的关键
|
2月前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
2月前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
81 3
|
2月前
|
SQL Oracle 关系型数据库
Oracle SQL:了解执行计划和性能调优
Oracle SQL:了解执行计划和性能调优
70 1
|
2月前
|
SQL 存储 数据库
慢SQL对数据库写入性能的影响及优化策略
在数据库管理系统中,慢SQL(即执行缓慢的SQL语句)不仅会影响查询性能,还可能对数据库的写入性能产生不利影响
|
4月前
|
SQL 存储 数据库
|
4月前
|
SQL 数据处理 数据库
SQL正则表达式应用:文本数据处理的强大工具——深入探讨数据验证、模式搜索、字符替换等核心功能及性能优化和兼容性问题
【8月更文挑战第31天】SQL正则表达式是数据库管理和应用开发中处理文本数据的强大工具,支持数据验证、模式搜索和字符替换等功能。本文通过问答形式介绍了其基本概念、使用方法及注意事项,帮助读者掌握这一重要技能,提升文本数据处理效率。尽管功能强大,但在不同数据库系统中可能存在兼容性问题,需谨慎使用以优化性能。
70 0

推荐镜像

更多
下一篇
DataWorks