跳到内容

Oracle SQL:了解执行计划和性能调优

更新时间
快连VPN:速度和安全性最佳的VPN服务
快连VPN:速度和安全性最佳的VPN服务
解释计划是犹如烹饪的艺术,旨在优化数据库查询。数据库系统根据自身的运行方式“解释”sql查询,执行计划展现了这一过程。通过审阅这些计划,我们能够了解优化器的选择,并通过修改来提升数据检索速度。

查询优化类似于制作完美食谱的艺术——它需要深入了解原料(数据)、厨房(数据库系统)和使用的技术(查询优化器)。每个数据库系统都有自己的处理和运行 SQL 查询的方式,“解释”计划向我们展示了这一切是如何运作的。通过查看这些计划,我们可以了解优化器做出的选择,并做出改进以加快数据检索速度。

在Oracle数据库中,优化器以其稳健性和复杂性而闻名,通常被描述为基于成本和基于规则的策略的组合。

在本文中,我们将探讨每个数据库如何生成和利用“解释”计划,并强调其方法的优势和潜在缺陷。无论您是数据库开发人员、数据库管理员还是数据分析师,了解这些机制都将使您能够有效地优化查询,确保更快、更可靠的数据检索。

解释计划在查询优化中的重要性

解释计划对于使选择查询更快、更高效非常有用。从中获取见解和解释也有助于优化查询速度和资源使用率。 

这就是为什么它们如此重要:

  • 性能洞察: 解释计划显示查询运行的路径。这告诉我们哪些部分真的很慢以及哪些部分需要改进。
  • 成本分析:解释计划中的每个操作都有相应的成本;此成本是一个估算值,它用作查询执行的各种方式之间的相对指标。查询成本越低,查询性能越快。
  • 索引利用率: 解释计划告诉我们索引是否正在使用以及如何使用。正确使用索引可能会使查询的处理非常快。
  • 连接策略:解释计划显示如何跨表连接涉及多个表的查询。了解这一点有助于优化表之间的关系。
  • 故障排除:当查询速度慢时,解释计划对于了解原因非常重要。事实上,它们可以准确地显示问题所在,使修复变得更容易。
  • 优化技术:在解释计划中,我们学习不同的查询优化技术,这些技术有时需要重写、数据库结构更改甚至配置更改。

定义和目的

基本上,执行计划是数据库引擎如何执行查询的分步说明。它概述了操作顺序、将要使用的索引以及连接表的方法。由于生成解释计划可能是一个资源密集型过程,因此了解其重要性至关重要。

解释计划的主要目的是让您深入了解查询的性能。通过分析解释计划,您可以了解数据库在哪些地方可以高效运行,或者在哪些地方可能遇到性能瓶颈。这种了解让您能够识别和解决潜在问题,从而帮助优化查询以获得更好的性能。

关键概念和术语

  • 执行计划(访问路径):数据库执行查询所遵循的路径。 
  • 成本:执行查询所需资源(如 CPU 和 I/O)的估计值。 
  • 操作: 特定的数据库操作,例如从表中读取或执行索引扫描。
  • 行数:每个操作将处理的预计行数。
  • 过滤器:行必须满足的条件才能进入查询处理的下一步。 
  • 连接方法:使用的连接类型,例如嵌套循环或哈希连接。
  • 字节:提供执行计划中每个操作将处理的数据量(以字节为单位)的估计值。
  • 例如图: 查询的解释计划输出示例:DB - Oracle:工具 - PLSQL Developer

总之,降低查询成本通常意味着执行时间更快,因为资源消耗减少,查询处理更高效。同样,更高的选择性可以提高索引的使用效率并减少处理的行数,从而提高查询性能。 

在 Oracle 中生成解释计划

使用EXPLAIN PLAN

Oracle 中的语句EXPLAIN PLAN为查询创建执行计划。

EXPLAIN PLAN FOR SELECT * FROM雇员;

这将创建一个可以查询的计划,用于DBMS_XPLAN.DISPLAY提供完整的视图。

使用DBMS_XPLAN.DISPLAY

上述查询创建了一个可以查询的解释计划,用于DBMS_XPLAN.DISPLAY提供完整的视图。 

SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY);

使用 Oracle SQL Developer 工具

您还可以使用快捷方式使用 SQL Developer 生成解释计划 - 按 F10。

实例

我们来看一下客户订单查询。

设想

由于缺少索引和连接方法不够理想,连接订单和客户两个表的查询运行缓慢。我们将通过添加索引和重写连接来优化查询。

识别慢查询

SELECT o.order_id, c.full_name

FROM orders o JOIN customers c

ON o.customer_id = c.customer_id

WHERE o.order_status = 'COMPLETE';

逐步解读计划

让我们从查询的解释计划开始。

问题

该查询执行全表扫描并使用哈希连接,导致性能缓慢。

解决方案

当您在查询中发现全表扫描时,请考虑将其替换为索引扫描。首先,检查是否已存在必要的索引;如果不存在,请在WHERE子句、JOIN条件和ORDER BY子句中使用的列上创建新的索引。

让我们首先尝试在连接条件(即连接和 where 子句的一部分的列)上创建索引。 

CREATE INDEX customers_idx0 ON customers (customer_id, full_name);

CREATE INDEX orders_idx1 ON orders (customer_id, order_id, order_status);

创建索引后收集表统计信息对于数据库优化器在查询执行计划上做出明智的决策至关重要。让我们收集表统计信息。

EXEC DBMS_STATS.gather_table_stats(SYS, 'CUSTOMERS');

EXEC DBMS_STATS.gather_table_stats(SYS, ORDERS);

现在我们重新检查一下添加这些索引后的执行计划。

成本从 8 降低到 6,这意味着通过使用索引快速全扫描和范围扫描替换全表扫描,成本提高了 25%。

通用优化策略

索引

创建索引通常会使查询运行得更快,因为这样可以避免数据扫描。正确的索引将使许多查询只需查找正确的行即可运行。

查询重写

有时,可以通过重写查询来提高查询性能,从而使其更加有效。通常,可以重写涉及复杂连接或有时子查询的查询,以获得更高效的执行计划。

执行计划缓存

然后它会缓存该计划以供重新执行,从而避免每次创建执行计划的开销。特别是,这允许许多查询使用以前计算的计划。

最佳实践

索引策略

  • 识别并创建索引: 识别运行缓慢的查询。创建适当的索引以加快数据检索速度。对于基于多列进行过滤的查询,请考虑使用复合索引来提高性能。
  • 避免过度索引:过多的索引会降低性能,尤其是 DML。定期检查并删除未使用或多余的索引。

查询设计

  • 简化查询:  尽可能将复杂的查询分解为更简单的部分。使用子查询和临时表来管理中间结果。
  • 避免SELECT *: 在语句中明确指定所需的列,SELECT以减少数据检索负载。
  • 适当使用连接: 选择INNER JOINs 来匹配行,并且OUTER JOIN仅在必要时使用 s。确保连接条件基于索引列。

执行计划分析

  • 定期检查执行计划:使用EXPLAIN命令(或等效工具)分析和理解查询执行计划。识别瓶颈和低效率。
  • 查找全表扫描: 通过添加索引或重组查询来识别并优化导致全表扫描的查询。
  • 监控成本和基数:关注执行计划中的预估成本和基数,以确保高效的查询路径。

 明智地使用查询提示

  • 指导优化器: 当您对数据和工作负载模式有更好的了解时,使用查询提示来影响优化器的选择。定期测试和验证提示对查询性能的影响,因为如果数据或工作负载发生变化,它们可能会导致次优计划。

结论

理解和利用解释计划对于优化数据库查询非常重要。通过掌握本文介绍的技巧和技术,数据库开发人员和管理员都可以大大提高查询性能。这反过来会提高数据库的整体效率,从而缩短响应时间并提高数据库管理效率。通过关注解释计划,您可以轻松识别和解决潜在的性能瓶颈,确保您的数据库以最佳状态运行。

例如,假设数据库开发人员/管理员在处理某些关键报告时遇到性能问题。他们可以轻松识别执行计划中成本高昂的全表扫描,并将其替换为索引搜索。结果,查询执行时间从几个小时缩短到几分钟。这不仅提高了系统的响应能力,还释放了资源用于其他任务,展示了利用执行计划的实际好处。

以上就是Oracle SQL:了解执行计划和性能调优的详细内容,更多请关注本站其它相关文章!

更新时间

发表评论

请注意,评论必须在发布之前获得批准。