前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >数据库备份/还原

数据库备份/还原

原创
作者头像
liliane
修改2023-05-15 11:08:52
4.7K0
修改2023-05-15 11:08:52
举报
文章被收录于专栏:liliane随笔liliane随笔

导语

开发的日常工作难免会遇到需要备份数据的场景,例如,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的备份操作。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 导语
  • mysql
    • 一、同库备份
      • 二、跨库备份
      • mongo
        • 一、同库备份
          • 二、跨库备份
          相关产品与服务
          数据库
          云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档