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;
相关推荐
2601_9495936533 分钟前
深入解析CANN-acl应用层接口:构建高效的AI应用开发框架
数据库·人工智能
javachen__33 分钟前
mysql新老项目版本选择
数据库·mysql
Dxy12393102161 小时前
MySQL如何高效查询表数据量:从基础到进阶的优化指南
数据库·mysql
Dying.Light1 小时前
MySQL相关问题
数据库·mysql
蜡笔小炘1 小时前
LVS -- 利用防火墙标签(FireWall Mark)解决轮询错误
服务器·数据库·lvs
韩立学长2 小时前
基于Springboot泉州旅游攻略平台d5h5zz02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·旅游
Re.不晚2 小时前
MySQL进阶之战——索引、事务与锁、高可用架构的三重奏
数据库·mysql·架构
老邓计算机毕设2 小时前
SSM智慧社区信息化服务平台4v5hv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·智慧社区、·信息化平台
麦聪聊数据3 小时前
为何通用堡垒机无法在数据库运维中实现精准风控?
数据库·sql·安全·低代码·架构
2301_790300963 小时前
Python数据库操作:SQLAlchemy ORM指南
jvm·数据库·python