PostgreSQL索引使用,备份pg_catalog数据

标签 postgresql indexing database-backups

我目前正在审查复杂 PostgreSQL 数据库中索引的使用情况。看起来有用的查询之一是这个

SELECT idstat.schemaname AS schema_name, idstat.relname AS table_name,
indexrelname AS index_name,
idstat.idx_scan AS times_used,
pg_size_pretty(pg_relation_size(idstat.relid)) AS table_size, pg_size_pretty(pg_relation_size(indexrelid)) AS index_size,
n_tup_upd + n_tup_ins + n_tup_del as num_writes,
indexdef AS definition
FROM pg_stat_user_indexes AS idstat JOIN pg_indexes ON (indexrelname = indexname AND idstat.schemaname = pg_indexes.schemaname)
JOIN pg_stat_user_tables AS tabstat ON idstat.relid = tabstat.relid
WHERE idstat.idx_scan  < 200
    AND indexdef !~* 'unique'
ORDER BY idstat.relname, indexrelname;

它告诉我索引的使用频率,它使用了多少空间等。

但是:

我从客户端站点获取数据库备份。当我恢复数据库时,查询为 times_used 返回零。我怀疑所有索引都在恢复时重建。

最后,问题:

从 pg_catalog 中捕获(备份)数据以便恢复和分析有关索引使用的实际客户端数据的最简单方法是什么?

最佳答案

提供客户端可以使用 psql -f report_on_live_db.sql live_db_name 运行的 SQL 脚本。让它SELECT所需的数据。

或者,您可以从客户端获取客户端数据库的原始文件系统级副本,然后在本地计算机上启动它。这只有在您可以在相同的操作系统和体系结构上运行 PostgreSQL 时才有效;您不能使用 64 位 PostgreSQL 访问 32 位数据库,也不能使用 Linux PostgreSQL 访问 Windows 或 BSD 数据库。必须使用相同的 PostgreSQL 主版本;您不能使用 9.1 访问 9.0 数据库,反之亦然。

关于PostgreSQL索引使用,备份pg_catalog数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14472065/

相关文章:

sql - 只向 PostgreSQL 表添加非重复值

sql - PostgreSQL 从 FUNCTION args 设置配置

python - 获取给定列的第一行值

c++ - 在运行之间保存 RocksDB 存储的值

mysql - Windows 上的 my.cnf 等效文件在哪里

sql - 删除 postgresql (SQL) 中的方括号

同一查询中的 PostgreSQL nextval 和 currval

indexing - 路由elasticsearch文档索引问题

python - Pandas 根据条件移动列数据

Azure SQL 数据库备份和恢复