Skip to content

Instantly share code, notes, and snippets.

@remino
Created January 30, 2012 02:55
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save remino/1702186 to your computer and use it in GitHub Desktop.
Save remino/1702186 to your computer and use it in GitHub Desktop.
MySQL dumps in Git repo
This is the old version. The newest can be found as a repo on GitHub:
https://github.com/remino/mysql2git
#!/bin/bash
#
# Dump schema and data of each table in selected or all databases of a MySQL
# host into a Git repo.
#
# It's recommended to set username and password in ~/.my.cnf:
#
# [client]
# user=root
# password=set_password_here
#
# See:
# http://www.viget.com/extend/backup-your-database-in-git/
# http://www.linuxjournal.com/node/1001956
#
mysql2git_main() {
[ $# -lt 1 ] && mysql2git_usage
GITCIMSG=""
MYSQLARGS=""
while getopts 'u:p:h:m:' opt; do
case $opt in
u) MYSQLARGS="$MYSQLARGS -u $OPTARG";;
p) MYSQLARGS="$MYSQLARGS -p$OPTARG";;
h) MYSQLARGS="$MYSQLARGS -h $OPTARG";;
m) GITCIMSG="$OPTARG";;
?) mysql2git_usage;;
esac
done
shift $(( OPTIND-1 ))
DUMPDIR=$1
[ ! -d "$DUMPDIR" ] && mkdir "$DUMPDIR"
cd "$DUMPDIR"
[ ! -e ".git" ] && git init .
shift
if [ $# -lt 1 ]; then
DBLIST=`echo show databases | mysql --vertical=false | tail -n +2`
else
DBLIST="$@"
fi
set +o noclobber
for db in $DBLIST; do
DBDIR="$db"
TABLELIST=`echo show tables | mysql -D $db --vertical=false | tail -n +2`
[ -d $DBDIR ] && rm -fr $DBDIR
mkdir -p $DBDIR
for table in $TABLELIST; do
tabledir="$DBDIR/$table"
mkdir -p "$tabledir"
mysqldump --skip-extended-insert --skip-dump-date --no-data \
$db $table > "$tabledir/schema.sql"
mysqldump --skip-extended-insert --skip-dump-date --no-create-info \
$db $table > "$tabledir/data.sql"
done
done
git add .
GITRMFILES="$( git ls-files --deleted )"
if [ "$GITRMFILES" != "" ]; then
git rm $GITRMFILES
fi
if [ "$GITCIMSG" == "" ]; then
git commit
else
git commit -m "$GITCIMSG"
fi
}
mysql2git_usage() {
echo "Usage: `basename $0` [options] dump-dir [db1 db2...]"
echo ""
echo " options:"
echo " -u username -p password -h host"
echo " MySQL username, password, and host."
echo " -m message"
echo " Git commit message."
exit 1
}
mysql2git_main $@
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment