我想保留所有MySQL数据库的备份。我有100多个MySQL数据库。我想同时导出所有这些文件,然后再一次将它们全部导入我的MySQL服务器。我该怎么做呢?
当前回答
导出Ubuntu中的所有数据库
1 - mysqldump -u root -p——databases database1 database2 > ~/Desktop/databases_1_2.sql
OR
2 - mysqldump -u root -p——all_databases > ~/Desktop/all_databases.sql
其他回答
出口:
mysqldump -u root -p --all-databases > alldb.sql
查阅mysqldump的文档。你可能想要使用评论中提到的一些选项:
mysqldump -u root -p --opt --all-databases > alldb.sql
mysqldump -u root -p --all-databases --skip-lock-tables > alldb.sql
进口:
mysql -u root -p < alldb.sql
我在这个问题上看到的所有答案都可能与某些数据库中的字符集有关,这是由于将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 -uroot - root——所有数据库> allDB.sql
注意:-u"你的用户名" - p“密码”
使用此命令成功导出所有数据库。
.\mysqldump -u root -p --all-databases > D:\laragon\tmp\alldb.sql
我的工具:Xampp, Windows Powershell
其他解决方案:
它将每个数据库备份到不同的文件中
#!/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