Regular Views:
Simply aliases for SQL queries, do not store data
Require query parsing and processing every time they are used
Can be slow for large/complex queries as query runs fully each time
Materialized Views:
Precompute and store results just like a table
Queries run directly on stored results, no parsing needed
Much faster for large/complex queries, act as a cache
Results need periodic refreshing to ensure they are up-to-date
https://www.postgresql.org/docs/current/rules-materializedviews.html
251% size of table
2SELECT pg_size_pretty(pg_table_size('table'))
3
4% cleanup cache
5VACUUM full;
6VACUUM (VERBOSE, ANALYZE) table_name;
7VACUUM (VERBOSE, ANALYZE) tasks;
8
9% activity
10SELECT datname,usename,client_addr,client_port FROM pg_stat_activity ;
11
12SELECT pid, (now() - query_start) FROM pg_stat_activity ;
13SELECT query FROM pg_stat_activity WHERE pid = 14274;
14
15
16SELECT COUNT(*) FROM pg_stat_activity;
17SELECT pid, query FROM pg_stat_activity WHERE query ILIKE '%ALTER%';
18
19SELECT pg_blocking_pids(pid) as blocked_by, pid FROM pg_stat_activity WHERE pid IN (16839, 14309)
20
21SELECT state, state_change, wait_event_type, wait_event FROM pg_stat_activity WHERE pid = 14309
22SELECT query FROM pg_stat_activity WHERE pid = 14309;
23
24SELECT pg_cancel_backend(14274);
25SELECT pg_terminate_backend(14274);
61pid | query
2-------+----------------------------------------------------------------------
314309 | alter table features_in_task +
4| add worker_uuid uuid
5
616839 | VACUUM full;
Database location
11ps aux | grep postgres | grep -- -D
Arrays and tuples
11WHERE client_user_id = ANY(ARRAY[175, 177, 166, 179])
61cur.execute(
2"SELECT count(*) FROM conversations "
3"WHERE client_id in %(clients_ids)s "
4"AND not deleted",
5{"clients_ids": tuple(clients_ids)},
6)
Group by day
31SELECT COUNT(id) FROM conversations
2WHERE created < now() - INTERVAL '14 day'
3GROUP BY to_char(created, 'yyyy-mm-dd')
151cursor.execute(
2 "SELECT users_voiceid_embeddings.* "
3 "FROM users_voiceid_embeddings "
4 "INNER JOIN users_voiceids ON users_voiceids.users_voiceid_id = users_voiceid_embeddings.users_voiceid_id "
5 "WHERE users_voiceid_embeddings.internal_user_id=%(internal_user_id)s "
6 "AND users_voiceid_embeddings.feature_id=%(feature_id)s "
7 "AND users_voiceids.voiceid_type = ANY(%(voiceid_type)s) "
8 "AND NOT users_voiceid_embeddings.is_deleted "
9 "AND NOT users_voiceids.is_deleted",
10 {
11 "internal_user_id": internal_user_id,
12 "feature_id": feature_id,
13 "voiceid_type": [str(it) for it in include_voiceid_types]
14 }
15 )
Avoid inserting twice if cannot use unique index (is_deleted case)
11sudo -u postgres psql
xxxxxxxxxx
11ALTER DATABASE table_name RENAME TO new_table_name;
xxxxxxxxxx
41PGPASSWORD="PASS" pg_dump -U asya --dbname=api --file=./dump-2021-12-10.sql --username=api --host=18.221.203.141 --port=543
2
3psql -U api -d api -W < /home/ubuntu/documents/backups/dump-2021-12-10.sql
4
https://www.postgresql.org/docs/9.3/app-pgdump.html
xxxxxxxxxx
61--schema-only \
2--column-inserts \
3--data-only \
4
5--table=app_strings \
6--table=app_strings_localized \
xxxxxxxxxx
51PGPASSWORD="PASS" pg_dump -U asya --dbname=api --file=./dump-2021-12-10.dmp --compress=9 --format=c --username=api --host=18.221.203.141 --port=5432
2
3pg_restore --jobs=8 --dbname=database /home/ubuntu/documents/backups/dump-2021-12-10.dmp
4
5sudo -u postgres pg_restore --jobs=8 --dbname=asya /dump-asya.dmp
xxxxxxxxxx
101ALTER TABLE table_name DISABLE TRIGGER ALL;
2
3
4-- Delete the rows from the table
5DELETE FROM table_name WHERE condition;
6
7-- Re-enable all triggers on the table
8ALTER TABLE table_name ENABLE TRIGGER ALL;
9ALTER TABLE tasks ENABLE TRIGGER ALL;
10;
xxxxxxxxxx
11sudo -u postgres psql
xxxxxxxxxx
11\c database
xxxxxxxxxx
11\dS table_name