Dav_笔记9:Using Indexes and Clusters之1

本节介绍以下内容:

■调整逻辑结构

■使用SQLAccess Advisor进行索引调整

调整逻辑结构

虽然查询优化有助于避免在查询执行中使用非选择性索引,但SQL引擎必须继续维护针对表定义的所有索引,无论查询是否使用它们。索引维护可以在任何写密集型应用程序中呈现显着的CPU和I / O资源需求。换句话说,除非必要,否则不要构建索引。

要保持最佳性能,请删除应用程序未使用的索引。您可以在代表工作负载的时间段内使用ALTER INDEX MONITORING USAGE功能查找未使用的索引。此监视功能记录是否已使用索引。如果您发现尚未使用索引,请将其删除。确保您正在监视代表性工作负载,以避免丢弃使用的索引,但不会删除您采样的工作负载。

此外,应用程序中的索引有时会使用对语句执行计划的调查不明显的用法。一个例子是父表上的外键索引,它可以防止在子表上取出共享锁。

如果您决定是否创建新索引来调优语句,那么您还可以使用EXPLAIN PLAN语句来确定优化程序是否在运行应用程序时选择使用这些索引。如果创建新索引以调整当前已解析的语句,则Oracle数据库将使该语句无效。

下次解析语句时,优化器会自动选择可能使用新索引的新执行计划。如果在远程数据库上创建新索引以调整分布式语句,则优化程序会在下一次解析语句时考虑这些索引。

请注意,创建用于调优一个语句的索引可能会影响优化程序对其他语句的执行计划的选择。例如,如果您创建一个索引供一个语句使用,那么优化器也可以选择将该索引用于应用程序中的其他语句。因此,重新检查应用程序的性能和执行计划,并在调整最初确定用于调优的语句后重新运行SQL跟踪工具。

使用SQLAccess Advisor进行索引调整

SQL Access Advisor是手动确定所需索引的替代方法。 从Oracle Enterprise Manager调用或通过DBMS_ADVISOR包API运行时,此顾问程序会建议一组索引。 SQL Access Advisor建议使用工作负载,或者为指定的模式生成假设的工作负载。

可以使用各种工作负载源,例如SQL缓存的当前内容,用户定义的SQL语句集或SQL调优集。 给定工作负载,SQL Access Advisor会生成一组建议,您可以从中选择要实现的索引。 提供了一个可以通过Oracle Enterprise Manager手动或自动执行的实现脚本。

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值