feat(app): added db maintance check stuff
This commit is contained in:
40
scripts/dbmaintance.ps1
Normal file
40
scripts/dbmaintance.ps1
Normal file
@@ -0,0 +1,40 @@
|
||||
# ===============================
|
||||
# PostgreSQL Maintenance Script
|
||||
# ===============================
|
||||
|
||||
# .\dbmaintance.ps1 -psql
|
||||
|
||||
param(
|
||||
[switch]$psql = "D:\Program Files\PostgreSQL\17\bin\psql.exe"
|
||||
)
|
||||
|
||||
# Config
|
||||
$env:PGPASSWORD = "obelix" # Or better: use pgpass.conf instead
|
||||
$dbUser = "postgres"
|
||||
$dbName = "lst_db"
|
||||
$dbHost = "localhost"
|
||||
$dbPort = "5432"
|
||||
|
||||
# Path to psql (adjust if PostgreSQL is installed elsewhere)
|
||||
|
||||
|
||||
# Show DB size before
|
||||
& $psql -h $dbHost -p $dbPort -U $dbUser -d $dbName -c "SELECT pg_size_pretty(pg_database_size(current_database())) AS size_before;"
|
||||
|
||||
# Run safe maintenance
|
||||
& $psql -h $dbHost -p $dbPort -U $dbUser -d $dbName -c "VACUUM (ANALYZE);"
|
||||
& $psql -h $dbHost -p $dbPort -U $dbUser -d $dbName -c "REINDEX DATABASE $dbName;"
|
||||
|
||||
# Show DB size after
|
||||
& $psql -h $dbHost -p $dbPort -U $dbUser -d $dbName -c "SELECT pg_size_pretty(pg_database_size(current_database())) AS size_after;"
|
||||
|
||||
# Optional: per-table size breakdown
|
||||
& $psql -h $dbHost -p $dbPort -U $dbUser -d $dbName -c @"
|
||||
SELECT
|
||||
schemaname || '.' || relname AS table_name,
|
||||
pg_size_pretty(pg_total_relation_size(relid)) AS total_size,
|
||||
pg_size_pretty(pg_relation_size(relid)) AS table_size,
|
||||
pg_size_pretty(pg_total_relation_size(relid) - pg_relation_size(relid)) AS index_size
|
||||
FROM pg_catalog.pg_statio_user_tables
|
||||
ORDER BY pg_total_relation_size(relid) DESC;
|
||||
"@
|
||||
Reference in New Issue
Block a user