oracle查询某数据库用户下哪些表的索引没有被使用到?

1. 开启所有索引的监控

sql 复制代码
-- 为指定用户下的所有索引开启监控
BEGIN
  FOR idx IN (SELECT owner, index_name FROM dba_indexes WHERE owner = 'YOUR_SCHEMA') 
  LOOP
    EXECUTE IMMEDIATE 'ALTER INDEX ' || idx.owner || '.' || idx.index_name || ' MONITORING USAGE';
  END LOOP;
END;
/

2. 运行一段时间后检查使用情况

sql 复制代码
-- 查看监控结果(需要DBA权限)
SELECT 
    u.owner,
    u.index_name,
    i.table_name,
    u.monitoring,
    u.used,
    u.start_monitoring,
    u.end_monitoring,
    i.index_type,
    i.uniqueness,
    i.status
FROM v$object_usage u
JOIN dba_indexes i ON u.index_name = i.index_name AND u.owner = i.owner
WHERE u.owner = 'YOUR_SCHEMA'
  AND u.used = 'NO'  -- 未使用的索引
ORDER BY i.table_name, u.index_name;

3. 关闭监控

sql 复制代码
-- 监控完成后关闭监控
BEGIN
  FOR idx IN (SELECT owner, index_name FROM dba_indexes WHERE owner = 'YOUR_SCHEMA') 
  LOOP
    EXECUTE IMMEDIATE 'ALTER INDEX ' || idx.owner || '.' || idx.index_name || ' NOMONITORING USAGE';
  END LOOP;
END;
/

4.查询AWR中索引使用统计(需要AWR许可)--推荐使用,可以获取哪些索引使用频繁最高,哪些索引使用频繁最低,适用于生产慢SQL优化

sql 复制代码
-- 查看过去N天内索引在AWR中的使用情况
SELECT 
    d.object_owner,
    d.object_name as index_name,
    t.table_name,
    COUNT(DISTINCT d.sql_id) as sql_count,
    COUNT(*) as plan_line_count,
    MIN(d.timestamp) as first_seen,
    MAX(d.timestamp) as last_seen
FROM dba_hist_sql_plan d
JOIN dba_indexes i ON d.object_owner = i.owner AND d.object_name = i.index_name
JOIN dba_tables t ON i.table_owner = t.owner AND i.table_name = t.table_name
WHERE d.object_owner = 'YOUR_SCHEMA'
  AND d.object_type = 'INDEX'
  AND d.timestamp > SYSDATE - 30  -- 最近30天
GROUP BY d.object_owner, d.object_name, t.table_name
ORDER BY sql_count ASC;  -- 使用次数少的排在前面

5.从未在AWR中出现的索引(可能从未使用)--推荐使用,用于优化生产无效索引

sql 复制代码
-- 找出从未在AWR执行计划中出现的索引
SELECT 
    i.owner,
    i.index_name,
    i.table_name,
    i.index_type,
    i.uniqueness,
    i.status,
    i.num_rows,
    i.leaf_blocks
FROM dba_indexes i
LEFT JOIN (
    SELECT DISTINCT object_owner, object_name
    FROM dba_hist_sql_plan
    WHERE object_type = 'INDEX'
      AND timestamp > SYSDATE - 90  -- 最近90天
) p ON i.owner = p.object_owner AND i.index_name = p.object_name
WHERE i.owner = 'YOUR_SCHEMA'
  AND p.object_name IS NULL  -- 从未出现在AWR中
  AND i.index_type NOT IN ('LOB', 'DOMAIN')  -- 排除特殊类型索引
ORDER BY i.table_name, i.index_name;
相关推荐
计算机安禾2 分钟前
【Linux从入门到精通】第33篇:数据库MySQL/MariaDB安装与基础调优
linux·数据库·mysql
瀚高PG实验室6 分钟前
ERROR: invalid input syntax for type integer: “a“
数据库·瀚高数据库
S1998_1997111609•X6 分钟前
论next/js在打击省份及犯罪行为集团的系统分析[特殊字符]设计
网络·数据库·百度·ssh·开闭原则
dfdfadffa11 分钟前
如何创建仅在首次订阅时执行一次计算的 RxJS 懒加载 Observable
jvm·数据库·python
Irene199113 分钟前
Oracle 中:为什么 from 子查询后面需要一个别名
数据库·oracle
m0_6245785915 分钟前
SQL分组后如何计算移动平均值_利用窗口函数AVG配合ROWS
jvm·数据库·python
2401_8242226922 分钟前
如何修复待办事项列表无法添加任务的 JavaScript 错误
jvm·数据库·python
地球资源数据云26 分钟前
1900-2023年中国物种分布点位矢量数据集
大数据·数据结构·数据库·数据仓库·人工智能
sitellla1 小时前
MySQL 入门:最流行的开源关系型数据库介绍
数据库·mysql·其他·开源
精益数智工坊1 小时前
拆解制造业仓库物料管理流程:如何通过标准化仓库物料管理流程解决账实不符难题
大数据·前端·数据库·人工智能·精益工程