我想保留所有MySQL数据库的备份。我有100多个MySQL数据库。我想同时导出所有这些文件,然后再一次将它们全部导入我的MySQL服务器。我该怎么做呢?


当前回答

我在这个问题上看到的所有答案都可能与某些数据库中的字符集有关,这是由于将mysqldump的出口重定向到shell操作符>中的一个文件的问题。

要解决这个问题,您应该使用这个命令行进行备份。-r标志的作用与shell操作符>相同,但没有字符集问题。

mysqldump -u root -p --opt --all-databases -r backup.sql

要在没有字符集问题的情况下进行良好的BD恢复,可以使用这些命令(您可以根据需要更改默认字符集)。

mysql -uroot -p --default-character-set=utf8
mysql> SET names 'utf8';
mysql> SOURCE backup.sql;

其他回答

当您正在转储所有数据库。显然,它拥有大量的数据。所以你可以选择下面的内容:

创建备份:

mysqldump -u [user] -p[password]--single-transaction --quick --all-databases | gzip > alldb.sql.gz

如果错误

——警告:跳过mysql.event表的数据。显式指定——events选项。

Use:

mysqldump -u [user] -p --events --single-transaction --quick --all-databases | gzip > alldb.sql.gz

恢复备份:

gunzip < alldb.sql.gz | mysql -u [user] -p[password]

希望对大家有所帮助:)

mysqldump -uroot - root——所有数据库> allDB.sql

注意:-u"你的用户名" - p“密码”

下面的脚本逐个导出和导入数据库,并在导入后不断删除sql文件。 [https://gist.github.com/Shubhamnegi/83b42c4ce80dbc9104c0f9413be17701] [1]

我写这篇评论已经4年多了,现在决定把它作为一个答案。

jruzafa的脚本可以简化一点:

#!/bin/bash

USER="zend"
PASSWORD=""
ExcludeDatabases="Database|information_schema|performance_schema|mysql"
databases=`mysql -u $USER -p$PASSWORD -e "SHOW DATABASES;" | tr -d "| " | egrep -v $ExcludeDatabases`

for db in $databases; do
    echo "Dumping database: $db"
    mysqldump -u $USER -p$PASSWORD --databases $db > `date +%Y%m%d`.$db.sql
done

注意:

排除的数据库(通常是系统表)在变量ExcludeDatabases中提供 请注意,密码是在命令行中提供的。这被认为是不安全的。研究这个问题。

其他解决方案:

它将每个数据库备份到不同的文件中

#!/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