MySQL сбрасывает все базы данных и создает (или воссоздает) их при импорте? - PullRequest
20 голосов
/ 20 января 2011

Мне было интересно, как я могу получить следующий файл,

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

, чтобы автоматически создавать любые базы данных, которые еще не созданы, при импорте.Кроме того, если база данных уже существует, она должна воссоздать ее (перезаписав старую).

Возможно ли это?Спасибо!

Ответы [ 3 ]

36 голосов
/ 21 января 2011
Export: mysqldump -u root -p --all-databases > all_dbs.sql
Import: mysql -u root -p < all_dbs.sql
7 голосов
/ 21 июля 2014

Экспорт:

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
1 голос
/ 31 июля 2014

не используйте команду «mysql» для экспорта данных. Пожалуйста, используйте вместо этого «mysqldump».

Я должен администрировать сервер, который сохраняет только:

\n

Exiting...

после выполнения "mysql --user = username --password = passord> somefile.sql"

...