Last active
December 31, 2015 02:29
-
-
Save rxw1/7920884 to your computer and use it in GitHub Desktop.
Dump tables and schema from a PostgreSQL database (nicely).
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/usr/bin/env zsh -e | |
# Thu Dec 12 00:04:47 CET 2013 | |
# 2013 (c) [email protected] | |
# Dump tables and schema from a PostgreSQL database. | |
# Usage: $0 [database_name] [num_records] | |
d=${1:=$USER} # database, defaults to current username | |
n=${2:=1000} # number of records to export, defaults to 1000 | |
tmp=$(mktemp -d -t ${0:t:r}_$d) | |
trap "{ cd - ; rm -rf $tmp; exit 255; }" SIGINT | |
a() { # get ugly psql table_name output from information_schema | |
psql -c "SELECT table_name FROM information_schema.tables WHERE table_schema = 'public';" $d | |
} | |
c=$((2 + $(a | egrep -o '[0-9]+'))) # table count | |
t=($(a | sed -n "s/^ //; 3,${c}p")) # tables | |
echo | |
for i in $t; do | |
psql -qec "COPY (SELECT * FROM $i LIMIT ${n}) TO '${tmp}/${i}_${n}.sql';" $d |\ | |
sed "s,${tmp}/,," | |
done | |
pg_dump -s -Ft $d > $tmp/${d}_schema.tar | |
echo | |
cd $tmp | |
tar cvjf $OLDPWD/${d}_sql_dumps_${n}.tar.bz2 *sql *schema* | |
cd - | |
echo "\n\e[0;31m>> \e[0;34m$(du -sh ./${d}_sql_dumps_${n}.tar.bz2)\e[0;0m" # :D | |
rm -rf $tmp | |
exit 0 |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment