Skip to content

Instantly share code, notes, and snippets.

@RockyMM
Forked from gingerlime/change_db_owner.sh
Last active September 22, 2021 22:47
Show Gist options
  • Save RockyMM/dd89aed75f3de9a2cd76 to your computer and use it in GitHub Desktop.
Save RockyMM/dd89aed75f3de9a2cd76 to your computer and use it in GitHub Desktop.
#!/bin/bash
usage()
{
cat << EOF
usage: $0 options
This script set ownership for all table, sequence and views for a given database
Credit: Based on http://stackoverflow.com/a/2686185/305019 by Alex Soto
Also merged changes from @sharoonthomas
OPTIONS:
-h Show this message
-d Database name
-o Owner
EOF
}
DB_NAME=
NEW_OWNER=
while getopts "hd:o:" OPTION
do
case $OPTION in
h)
usage
exit 1
;;
d)
DB_NAME=$OPTARG
;;
o)
NEW_OWNER=$OPTARG
;;
esac
done
if [[ -z $DB_NAME ]] || [[ -z $NEW_OWNER ]]
then
usage
exit 1
fi
for tbl in `psql -qAt -c "select schemaname || '.' || tablename from pg_tables where schemaname <> 'pg_catalog' and schemaname <> 'information_schema';" ${DB_NAME}` \
`psql -qAt -c "select sequence_schema || '.' || sequence_name from information_schema.sequences where sequence_schema <> 'pg_catalog' and sequence_schema <> 'information_schema';" ${DB_NAME}` \
`psql -qAt -c "select table_schema || '.' || table_name from information_schema.views where table_schema <> 'pg_catalog' and table_schema <> 'information_schema';" ${DB_NAME}` ;
do
psql -c "alter table $tbl owner to ${NEW_OWNER}" ${DB_NAME} ;
done
@RockyMM
Copy link
Author

RockyMM commented Mar 16, 2015

The tables in my database are prevalently not in 'public' schema, so this is my change.

@RockyMM
Copy link
Author

RockyMM commented Mar 16, 2015

Added schema names.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment