ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
# 28.1\. 判断磁盘的使用量 每个表都有一个主堆(primary heap)磁盘文件,大多数数据都存储在这里。如果一个表存在值可能会很长的字段, 则另外还有一个用于存储因为数值太长而不适合存储在主表中的数据的TOAST文件 (参阅[Section 58.2](#calibre_link-80))。如果存在这个扩展表,那么将会同时存在一个TOAST索引。 当然,同时还可能有索引和基表关联。每个表和索引都存放在单独的磁盘文件里(超过 1GB 可能会被分割成多个)。 这些文件的命名原则在[Section 58.1](#calibre_link-1511)里描述。 可以使用三种方法监视磁盘空间:使用[Table 9-64](#calibre_link-1073)中列出的 SQL 函数、 使用[oid2name](#calibre_link-630)模块、或使用手动检查系统表。SQL 函数是最简单的方法并且一般推荐使用它。 本节其余部分显示了如何通过检查系统表来监视磁盘空间。 在最近刚刚清理(或者分析过)的数据库上使用psql的话, 可以使用查询来查看任意表的磁盘使用: ``` SELECT pg_relation_filepath(oid), relpages FROM pg_class WHERE relname = 'customer'; pg_relation_filepath | relpages ----------------------+---------- base/16384/16806 | 60 (1 row) ``` 每个页通常都是 8K 字节。注意,`relpages`只被`VACUUM`, `ANALYZE` 和几个 DDL 命令(例如`CREATE INDEX`)更新。如果你想直接检查表的磁盘文件, 那么可以使用文件路径名。 要显示TOAST表使用的空间,我们可以使用一个类似下面这样的查询: ``` SELECT relname, relpages FROM pg_class, (SELECT reltoastrelid FROM pg_class WHERE relname = 'customer') AS ss WHERE oid = ss.reltoastrelid OR oid = (SELECT reltoastidxid FROM pg_class WHERE oid = ss.reltoastrelid) ORDER BY relname; relname | relpages ----------------------+---------- pg_toast_16806 | 0 pg_toast_16806_index | 1 ``` 也可以很容易地显示索引的尺寸: ``` SELECT c2.relname, c2.relpages FROM pg_class c, pg_class c2, pg_index i WHERE c.relname = 'customer' AND c.oid = i.indrelid AND c2.oid = i.indexrelid ORDER BY c2.relname; relname | relpages ----------------------+---------- customer_id_indexdex | 26 ``` 很容易用下面的信息找出最大的表和索引: ``` SELECT relname, relpages FROM pg_class ORDER BY relpages DESC; relname | relpages ----------------------+---------- bigtable | 3290 customer | 3144 ```