дамп всех таблиц mysql в отдельные файлы автоматически?
Я хотел бы получить дампы каждой таблицы mysql в отдельные файлы. В руководстве указано, что синтаксис для этого
mysqldump [options] db_name [tbl_name ...]
что означает, что вы знаете имена таблиц перед рукой. Я мог бы настроить скрипт, который теперь знает каждое имя таблицы, но скажем, я добавляю новую таблицу по дороге и забываю обновить скрипт дампа. Тогда мне не хватает дампов для одного или нескольких столов.
есть ли способ автоматически сбрасывать каждую существующую таблицу в отдельный файл? Или я придется сделать какой-то скрипт-фу; запросить базу данных, получить все имена таблиц и сбросить их по имени.
Если я иду по маршруту script-fu, какие скриптовые языки могут получить доступ к базе данных mysql?
8 ответов:
программа командной строки mysqldump делает это за вас-хотя документы очень неясно об этом.
одна вещь, чтобы отметить, что ~ / output / dir должен быть доступен для записи пользователем, который владеет mysqld. На Mac OS X:
sudo chown -R _mysqld:_mysqld ~/output/dir mysqldump --user=dbuser --password --tab=~/output/dir dbname
после запуска выше, вы будете иметь одно имя таблицы.файл sql, содержащий схему каждой таблицы (оператор create table) и имя таблицы.текстовый файл, содержащий данные.
Если вы хотите дамп только со схемой, добавьте -- флаг без данных:
mysqldump --user=dbuser --password --no-data --tab=~/output/dir dbname
вот скрипт, который сбрасывает табличные данные в виде команд SQL в отдельные сжатые файлы. Он не требует нахождения на хосте сервера MySQL, не жестко кодирует пароль в скрипте и предназначен только для конкретной БД, а не для всех БД на сервере:
#!/bin/bash # dump-tables-mysql.sh # Descr: Dump MySQL table data into separate SQL files for a specified database. # Usage: Run without args for usage info. # Author: @Trutane # Ref: http://stackoverflow.com/q/3669121/138325 # Notes: # * Script will prompt for password for db access. # * Output files are compressed and saved in the current working dir, unless DIR is # specified on command-line. [ $# -lt 3 ] && echo "Usage: $(basename ) <DB_HOST> <DB_USER> <DB_NAME> [<DIR>]" && exit 1 DB_host= DB_user= DB= DIR= [ -n "$DIR" ] || DIR=. test -d $DIR || mkdir -p $DIR echo -n "DB password: " read -s DB_pass echo echo "Dumping tables into separate SQL command files for database '$DB' into dir=$DIR" tbl_count=0 for t in $(mysql -NBA -h $DB_host -u $DB_user -p$DB_pass -D $DB -e 'show tables') do echo "DUMPING TABLE: $DB.$t" mysqldump -h $DB_host -u $DB_user -p$DB_pass $DB $t | gzip > $DIR/$DB.$t.sql.gz tbl_count=$(( tbl_count + 1 )) done echo "$tbl_count tables dumped from database '$DB' into dir=$DIR"
Вы можете сделать это:
- получить список баз данных в MySQL
- дамп каждой базы данных с
mysqldump
# Optional variables for a backup script MYSQL_USER="root" MYSQL_PASS="something" BACKUP_DIR=/srv/backup/$(date +%Y-%m-%dT%H_%M_%S); test -d "$BACKUP_DIR" || mkdir -p "$BACKUP_DIR" # Get the database list, exclude information_schema for db in $(mysql -B -s -u $MYSQL_USER --password=$MYSQL_PASS -e 'show databases' | grep -v information_schema) do # dump each database in a separate file mysqldump -u $MYSQL_USER --password=$MYSQL_PASS "$db" | gzip > "$BACKUP_DIR/$db.sql.gz" done
вот соответствующий импорт.
#!/bin/bash # import-files-mysql.sh # Descr: Import separate SQL files for a specified database. # Usage: Run without args for usage info. # Author: Will Rubel # Notes: # * Script will prompt for password for db access. [ $# -lt 3 ] && echo "Usage: $(basename ) <DB_HOST> <DB_USER> <DB_NAME> [<DIR>]" && exit 1 DB_host= DB_user= DB= DIR= DIR=$DIR/* echo -n "DB password: " read -s DB_pass echo echo "Importing separate SQL command files for database '$DB' into '$DB'" file_count=0 for f in $DIR do echo "IMPORTING FILE: $f" gunzip -c $f | mysql -h $DB_host -u $DB_user -p$DB_pass $DB (( file_count++ )) done echo "$file_count files importing to database '$DB'"
#!/bin/bash for i in $(mysql -uUser -pPASSWORD DATABASE -e "show tables;"|grep -v Tables_in_);do mysqldump -uUSER -pPASSWORD DATABASE $i > /backup/dir/$i".sql";done tar -cjf "backup_mysql_"$(date +'%Y%m%d')".tar.bz2" /backup/dir/*.sql
похоже, все здесь забыли
autocommit=0;SET unique_checks=0;SET foreign_key_checks=0;
то есть предполагается ускорить процесс импорта ...#!/bin/bash MYSQL_USER="USER" MYSQL_PASS="PASS" if [ -z "" ] then echo "Dumping all DB ... in separate files" for I in $(mysql -u $MYSQL_USER --password=$MYSQL_PASS -e 'show databases' -s --skip-column-names); do echo "SET autocommit=0;SET unique_checks=0;SET foreign_key_checks=0;" > "$I.sql" mysqldump -u $MYSQL_USER --password=$MYSQL_PASS $I >> "$I.sql"; echo "SET autocommit=1;SET unique_checks=1;SET foreign_key_checks=1;commit;" >> "$I.sql" gzip "$I.sql" done echo "END." else echo "Dumping ..." echo "SET autocommit=0;SET unique_checks=0;SET foreign_key_checks=0;" > ".sql" mysqldump -u $MYSQL_USER --password=$MYSQL_PASS >> ".sql"; echo "SET autocommit=1;SET unique_checks=1;SET foreign_key_checks=1;commit;" >> ".sql" gzip ".sql" fi
Я не мастер bash, но я бы просто сделал это с помощью сценария bash. Не нажимая MySQL, со знанием каталога данных и имени базы данных, вы можете просто сканировать все .файлы frm (по одному для каждой таблицы в этом каталоге db/) для списка таблиц.
Я уверен, что есть способы сделать его более гладким и принять аргументы или что-то еще, но это хорошо сработало для меня.
tables_in_a_db_to_sql.sh
#!/bin/bash database="this_is_my_database" datadir="/var/lib/mysql/" datadir_escaped="\/var\/lib\/mysql\/" all_tables=($(ls $datadir$database/*.frm | sed s/"$datadir_escaped$database\/"/""/g | sed s/.frm//g)) for t in "${all_tables[@]}"; do outfile=$database.$t.sql echo "-- backing up $t to $outfile" echo "mysqldump [options] $database $t > $outfile" # mysqldump [options] $database $t > $outfile done
заполните [параметры] и желаемое соглашение outfile как вам нужно, и раскомментируйте последнюю строку команды mysqldump.
смотрите следующую статью Паули Маркуса:
как разделить дамп базы данных SQL на табличные файлы
разбиение файла sql, содержащего целую базу данных, на файлы для каждой таблицы довольно легко: Grep the .sql для любого появления таблицы DROP. Генерировать имя файла из имени таблицы, включенной в таблицу отбрасывания заявление. Эхо-вывод в файл. Вот небольшой скрипт, который ожидает .sql файл как вход:
#!/bin/bash file= # the input file directory="$file-splitted" # the output directory output="$directory/header" # the first file containing the header GREP="DROP TABLE" # what we are looking for mkdir $directory # create the output directory while read line do # if the current line contains the wanted statement if [ $(echo "$line" | grep -c "$GREP") == "1" ] then # extract the file name myfile=$(echo $line | awk '{print }' | sed -e 's/`//g' -e 's/;//g') # set the new file name output="$directory/$myfile" fi echo "$line" >> $output # write to file done < $file