web-dev-qa-db-ja.com

MySQLはすべてのデータベースをダンプし、インポート時にそれらを作成(または再作成)しますか?

次のファイルを取得するにはどうすればよいかと思っていました。

mysqldump -h server -u root -p --all-databases > all_dbs.sql

インポート時に、まだ作成されていないデータベースを自動的に作成します。また、データベースがすでに存在する場合は、データベースを再作成する必要があります(古いデータベースを上書きします)。

これは可能ですか?ありがとう!

21
Garrett
Export: mysqldump -u root -p --all-databases > all_dbs.sql
Import: mysql -u root -p < all_dbs.sql
37
Garrett

エクスポート:

mysqldump -uroot -p --all-databases > alldb.sql

Mysqldumpのドキュメントを検索します。コメントで言及されているオプションのいくつかを使用したい場合があります。

mysqldump -uroot -p --opt --all-databases > alldb.sql
mysqldump -uroot -p --all-databases --skip-lock-tables> alldb.sql

インポート:

mysql -u root -p < alldb.sql

私は新しい解決策を見つけました:

Bashスクリプトを作成します。各データベースを異なるファイルにバックアップします

#!/bin/bash

USER="zend"
PASSWORD=""
#OUTPUT="/Users/rabino/DBs"

#rm "$OUTPUTDIR/*gz" > /dev/null 2>&1

databases=`mysql -u $USER -p$PASSWORD -e "SHOW DATABASES;" | tr -d "| " | grep -v Database`

for db in $databases; do
    if [[ "$db" != "information_schema" ]] && [[ "$db" != "performance_schema" ]] && [[ "$db" != "mysql" ]] && [[ "$db" != _* ]] ; then
        echo "Dumping database: $db"
        mysqldump -u $USER -p$PASSWORD --databases $db > `date +%Y%m%d`.$db.sql
       # gzip $OUTPUT/`date +%Y%m%d`.$db.sql
    fi
done
9
Suneel Kumar

「mysql」コマンドを使用してデータをエクスポートしないでください。代わりに「mysqldump」を使用してください。

保存のみのサーバーを管理する必要があります。

\n

Exiting...

「mysql --user = username --password = passord> somefile.sql」を実行した後

1
user3895544

/ applications/MAMP/library/bin/mysqldump -u root -p --all-databases> all_dbs.sql

0
M6R7M