列出数据库中不再使用的所有索引,PostgreSQL

List all indexes that not in use anymore in database, PostgreSQL

我试图在特定数据库上使用 9.5 版的 PostgreSQL 查找不再使用的索引。

我该怎么做?

以下查询将为您提供相对未使用的索引 (idx_scan<50):

SELECT schemaname || '.' || relname AS table,
       indexrelname AS index,
       pg_size_pretty(pg_relation_size(i.indexrelid)) AS index_size,
       idx_scan as index_scans
FROM pg_stat_user_indexes ui
  JOIN pg_index i ON ui.indexrelid = i.indexrelid
WHERE NOT indisunique 
  AND idx_scan < 50 
  AND pg_relation_size(relid) > 5 * 8192
ORDER BY pg_relation_size(i.indexrelid) / nullif(idx_scan, 0) DESC NULLS FIRST,
      pg_relation_size(i.indexrelid) DESC;