Curated list of useful resources and cheatsheets for web developers
View the Project on GitHub zlatanstajic/ultimate-cheatsheet-for-developers
Open source relational database management system.
Read more about PostgreSQL.
See also: MySQL — alternative relational database; Docker — commonly run as a containerized service.
# Connect to a database (prompts for password)
psql -U [username] -h [host] -d [database-name]
# Connect with port
psql -U [username] -h [host] -p [port] -d [database-name]
# Connect using a connection string
psql "postgresql://[username]:[password]@[host]:[port]/[database-name]"
The following commands are run inside the psql interactive shell:
-- List all databases
\l
-- Connect to a database
\c [database-name]
-- List all tables in current schema
\dt
-- Describe a table (columns, types, constraints)
\d [table-name]
-- List all schemas
\dn
-- List all users/roles
\du
-- Show current connection info
\conninfo
-- Show query execution time
\timing
-- Execute SQL from a file
\i [path-to-file.sql]
-- Quit psql
\q
# Dump to plain SQL file
pg_dump -U [username] -h [host] -d [database-name] -f [dump-filename].sql
# Dump in custom format (compressed, supports parallel restore — preferred for large databases)
pg_dump -U [username] -h [host] -Fc -d [database-name] -f [dump-filename].dump
# Dump a specific table only
pg_dump -U [username] -h [host] -d [database-name] -t [table-name] -f [dump-filename].sql
# Dump schema only (no data)
pg_dump -U [username] -h [host] -d [database-name] --schema-only -f [dump-filename].sql
# Dump data only (no schema)
pg_dump -U [username] -h [host] -d [database-name] --data-only -f [dump-filename].sql
# Restore from plain SQL dump
psql -U [username] -h [host] -d [database-name] < [path-to-dump-file].sql
# Restore from custom format dump (use pg_restore)
pg_restore -U [username] -h [host] -d [database-name] [path-to-dump-file].dump
# Restore with parallel jobs (faster for large databases)
pg_restore -U [username] -h [host] -d [database-name] -j [num-jobs] [path-to-dump-file].dump