我想知道如何获得以下文件,
mysqldump -h server -u root -p --all-databases > all_dbs.sql
在导入时自动创建尚未创建的任何数据库。此外,如果数据库已存在,则应重新创建它(覆盖旧数据库)。
这可能吗?谢谢!
答案 0 :(得分:36)
Export: mysqldump -u root -p --all-databases > all_dbs.sql
Import: mysql -u root -p < all_dbs.sql
答案 1 :(得分:7)
导出:强>
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
答案 2 :(得分:1)
不要使用&#34; mysql&#34;命令导出数据。请使用&#34; mysqldump&#34;代替。
我必须管理仅保存的服务器:
\n
Exiting...
执行&#34; mysql --user = username --password = passord&gt; somefile.sql&#34;
答案 3 :(得分:0)
/ applications / MAMP / library / bin / mysqldump -u root -p --all-databases> all_dbs.sql