PostgreSQL 查看重复索引

在进行数据表结构的设计和 SQL 优化的过程中,有时候会遇到这样的场景,索引被重复创建,那么如何找出这些被重复创建的索引呢,下面这个语句可以帮助到我们。

WITH sub AS ( SELECT indrelid::regclass AS relname,

indexrelid::regclass AS idx,

(indrelid::text || indclass::text || indkey::text || COALESCE(indexprs::text, '') || COALESCE(indpred::text, '')) AS KEY

FROM pg_index )

SELECT relname,

(array_agg(idx))[1] idx1,

pg_get_indexdef((array_agg(idx))[1]) idx1_def,

(array_agg(idx))[2] idx2,

pg_get_indexdef((array_agg(idx))[2]) idx2_def,

(array_agg(idx))[3] idx3,

pg_get_indexdef((array_agg(idx))[3]) idx3_def

FROM sub

GROUP BY relname, KEY

HAVING count(*) > 1;

备注:找出这些重复索引,然后根据需要进行删除。

相关推荐
E___V___E20 分钟前
黑马点评redis改 part 1
数据库·redis·缓存
BenBen尔1 小时前
为什么InnoDB中意向锁IX和IX可以兼容
数据库
加油,旭杏1 小时前
【Redis】通用命令
数据库·redis·缓存
信徒_1 小时前
MySQL 中的 MVCC 版本控制机制原理
数据库·mysql
车载测试工程师2 小时前
ARXML文件解析-2
java·服务器·网络·数据库·经验分享·网络协议·车载系统
爱编程的王小美2 小时前
MongoDB基础知识
数据库·mongodb
zm2 小时前
C高级,终端操作
服务器·postgresql·php
mumu-hn3 小时前
Flask使用MySQL数据库通过Flask-SQLAlchemy 迁移数据库,实际更新文件,但是提示没有检测到数据更新。
数据库·mysql·flask
潇凝子潇3 小时前
Mac OS 禁用 SIP 系统完整性保护
数据库·mysql
喻师傅3 小时前
横扫SQL面试——PV、UV问题
大数据·数据库·sql·面试·数据分析·uv