各mysqlテーブルのダンプを個別のファイルに取得したいと思います。マニュアルでは、これの構文は
mysqldump [options] db_name [tbl_name ...]
これは、事前にテーブル名を知っていることを示しています。各テーブル名を知っているスクリプトを設定することもできますが、新しいテーブルを追加して、ダンプスクリプトの更新を忘れると言います。次に、1つ以上のテーブルのダンプがありません。
既存の各テーブルを個別のファイルに自動的にダンプする方法はありますか?または、スクリプトフーをしなければなりません。データベースを照会し、すべてのテーブル名を取得し、名前でダンプします。
Script-fuルートに行くと、どのスクリプト言語がmysqlデータベースにアクセスできますか?
Mysqldumpコマンドラインプログラムがこれを行います-ただし、 ドキュメント はこれについて非常に不明確です。
注意すべきことの1つは、mysqldを所有するユーザーが〜/ output/dirに書き込み可能である必要があることです。 Mac OS Xの場合:
Sudo chown -R _mysqld:_mysqld ~/output/dir
mysqldump --user=dbuser --password --tab=~/output/dir dbname
上記を実行すると、各テーブルのスキーマを含む1つのtablename.sqlファイル(create tableステートメント)と、データを含むtablename.txtファイルが作成されます。
スキーマのみのダンプが必要な場合は、-no-dataフラグを追加します。
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 $0) <DB_Host> <DB_USER> <DB_NAME> [<DIR>]" && exit 1
DB_Host=$1
DB_user=$2
DB=$3
DIR=$4
[ -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"
これは次の方法で実現できます。
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 $0) <DB_Host> <DB_USER> <DB_NAME> [<DIR>]" && exit 1
DB_Host=$1
DB_user=$2
DB=$3
DIR=$4
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 "$1" ]
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 $1 ..."
echo "SET autocommit=0;SET unique_checks=0;SET foreign_key_checks=0;" > "$1.sql"
mysqldump -u $MYSQL_USER --password=$MYSQL_PASS $1 >> "$1.sql";
echo "SET autocommit=1;SET unique_checks=1;SET foreign_key_checks=1;commit;" >> "$1.sql"
gzip "$1.sql"
fi
すべてのデータベースからすべてのテーブルをダンプする場合は、Elias Torres ArroyoとTrutaneの答えを組み合わせてください。そして、ターミナルでパスワードを指定したくない場合は、追加の設定ファイル(chmod 0600)にパスワードを保存します。 cronおよびパスワードセキュリティによって起動されるMysqldump
#!/usr/bin/env bash
# this file
# a) gets all databases from mysql
# b) gets all tables from all databases in a)
# c) creates subfolders for every database in a)
# d) dumps every table from b) in a single file
# this is a mixture of scripts from Trutane (http://stackoverflow.com/q/3669121/138325)
# and Elias Torres Arroyo (https://stackoverflow.com/a/14711298/8398149)
[ $# -lt 3 ] && echo "Usage: $(basename $0) <DB_Host> <DB_USER> <DIR>" && exit 1
DB_Host=$1
DB_user=$2
BACKUP_DIR=$3/$(date +%Y-%m-%dT%H_%M_%S);
test -d "$BACKUP_DIR" || mkdir -p "$BACKUP_DIR"
# Get the database list, exclude information_schema
database_count=0
tbl_count=0
for db in $(mysql --defaults-extra-file=/yourfile/config.cnf -B -s -u $DB_user -e 'show databases' | grep -v information_schema)
do
# dump each database in a separate file
(( database_count++ ))
DIR=$BACKUP_DIR/$db
[ -n "$DIR" ] || DIR=.
test -d $DIR || mkdir -p $DIR
echo
echo "Dumping tables into separate SQL command files for database '$db' into dir=$DIR"
for t in $(mysql --defaults-extra-file=/yourfile/config.cnf -NBA -h $DB_Host -u $DB_user -D $db -e 'show tables')
do
echo "DUMPING TABLE: $db.$t"
mysqldump --defaults-extra-file=/yourfile/config.cnf -h $DB_Host -u $DB_user $db $t > $DIR/$db.$t.sql
tbl_count=$(( tbl_count + 1 ))
done
echo "Database $db is finished"
done
echo "Backup completed"
私はbashマスターではありませんが、bashスクリプトを使用してそれを行うだけです。 MySQLにアクセスすることなく、データディレクトリとデータベース名を知っていれば、すべての.frmファイル(そのdb /ディレクトリ内のすべてのテーブルに1つ)をスキャンしてテーブルのリストを取得できます。
私はそれをよりスマートにし、議論などを受け入れる方法があると確信していますが、これは私にとってうまくいきました。
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
必要に応じて、[オプション]と必要な出力ファイルの規則を入力し、最後のmysqldump行のコメントを解除します。