导语
开发的日常工作难免会遇到需要备份数据的场景,例如,DB特性变更,为了能备份便于回滚,亦或是,需要从不同服务器导数据。本文记录mysql、mongo数据库的常用导入/导出操作,方便查阅。
mysql
一、同库备份
代码语言:javascript复制insert into new_tablename select * from original_tablename;
本质是基于一张表创建另一张表,注意需保持两张表的schema一致。
二、跨库备份
1. 导出数据
代码语言:javascript复制mysqldump -h host -P port -u username -p --databases dbname --tables tablename > xxx.sql;
// 带查询条件导出
mysqldump -h host -P port -u username -p --databases dbname --tables tablename --where="id > 100" > xxx.sql
2. 恢复数据
代码语言:javascript复制mysql -h host -P port -u username -p tablename < xxx.sql;
mongo
一、同库备份
代码语言:javascript复制db.xxx.find({}).forEach(
function(item) {
db.xxx_bak.insert(item)
}
)
本质是,遍历collection,将所有记录逐一写入备份collection。
二、跨库备份
1. 导出数据
代码语言:javascript复制mongodump -h 数据库ip --port 端口 -d 库名 -u用户名 -p密码 -o 输出文件名
2. 恢复数据
代码语言:javascript复制mongorestore -h 数据库ip --port 端口 -d 库名 -u用户名 -p密码 待导入文件名
ps:后续补充 clickhouse 等其他DB的备份操作。