Total Database Size
This SQL simply gets the total size of the database in a human readable format.
SELECT pg_size_pretty(pg_database_size('postgres')) as db_size
data:image/s3,"s3://crabby-images/74f21/74f21703c9602b766dd40498b1d3481bb9620f13" alt=""
List all Tables
This lists all the tables in the database public schema.
SELECT tablename FROM pg_catalog.pg_tables WHERE schemaname = 'public'
data:image/s3,"s3://crabby-images/b193a/b193a9edad59e3ad82dc57ffb77be0523ac76d8e" alt=""
Search Schema for Column Name
I often need to search all the tables or views to find which contain a particular column. Replace ‘COLUMN_NAME’ with your column below.
SELECT t.table_schema,t.table_name FROM information_schema.tables t INNER JOIN information_schema.columns c ON c.table_name = t.table_name AND c.table_schema = t.table_schema WHERE c.column_name = 'COLUMN_NAME' AND t.table_schema not in ('information_schema', 'pg_catalog') AND t.table_type = 'BASE TABLE' ORDER BY t.table_schema;
In this case I searched for all columns containing the word ‘order’.
data:image/s3,"s3://crabby-images/5e2e1/5e2e1c27f5bd2963deccd698b0d43e5e843eecc3" alt=""
Table Sizes
Retrieve the size per table in the public schema from largest to smallest.
SELECT nspname || '.' || relname AS "table_name", pg_size_pretty(pg_total_relation_size(C.oid)) AS "total_size" FROM pg_class C LEFT JOIN pg_namespace N ON (N.oid = C.relnamespace) WHERE nspname = 'public' AND C.relkind <> 'i' AND nspname !~ '^pg_toast' ORDER BY pg_total_relation_size(C.oid) DESC
data:image/s3,"s3://crabby-images/dd440/dd4404239024f1a7ef9bd5c542a48e821db2b108" alt=""
Full Schema
SELECT * FROM information_schema.columns WHERE table_schema = 'public'
data:image/s3,"s3://crabby-images/17c2b/17c2b74e08cd2754350ac5f606b500813ed89cac" alt=""