我想保留所有MySQL数据库的备份。我有100多个MySQL数据库。我想同时导出所有这些文件,然后再一次将它们全部导入我的MySQL服务器。我该怎么做呢?
当前回答
使用此命令成功导出所有数据库。
.\mysqldump -u root -p --all-databases > D:\laragon\tmp\alldb.sql
我的工具:Xampp, Windows Powershell
其他回答
导出数据库:
对于导出,你可以使用这个命令:
mysqldump -u root -p --all-databases > alldb.sql
↓ ↓
(you user name) (file name will be save)
实际上,我写这篇文章是因为没有理由在一个文件中备份所有的数据库。它可能会导致一个错误,当你导入它。 例如,有一些默认数据库,没有理由备份它们。
因此,您应该选择要备份的数据库。
mysqldump -u root -p --databases YourDBName1 YourDBName2 YourDBName3 > tutorials_query1.sql
↓ ↓ ↓
(your databases name that you want to backup)
你可以用这个命令获取所有数据库的名称:
sudo mysql -u root -p
然后输入密码,然后在mysql>前面运行这个命令:
SHOW DATABASES;
导入数据库:
mysql -u root -p < alldb.sql
↓ ↓
(your username) (it can be the full path like "/home/yoursqlfile.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“密码”
为什么解析格式化的输出,而mysql命令可以直接做你想做的?
databases=`mysql -u $USER -p$PASSWORD --batch --skip-column-names -e "SHOW DATABASES;" | grep -E -v "(information|performance)_schema"`
仅列出数据库名称。
其他解决方案:
它将每个数据库备份到不同的文件中
#!/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
推荐文章
- 在MySQL中选择最后一行
- 如何删除MySQL root密码
- MySQL对重复键更新在一个查询中插入多行
- mysql_connect():[2002]没有这样的文件或目录(试图通过unix:///tmp/mysql.sock连接)在
- MySQL:如何复制行,但改变几个字段?
- 不能删除或更新父行:外键约束失败
- Mysql错误1452:不能添加或更新子行:外键约束失败
- MySQL DISTINCT在GROUP_CONCAT()上
- 第一次设计数据库:我是否过度设计了?
- MySQL选择一个列DISTINCT,与其他列相对应
- 错误1022 -不能写;表中重复的键
- 如何修改列和更改默认值?
- 如何在MySQL 8.0中授予root用户所有权限
- mysqld_safe UNIX套接字文件目录“/var/run/mysqld”不存在
- 配置系统初始化失败