mysql备份数据库时怎样只备份一个数据库中的其中几张表的数据,覆盖时只覆盖这几张表的内容

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql备份数据库时怎样只备份一个数据库中的其中几张表的数据,覆盖时只覆盖这几张表的内容相关的知识,希望对你有一定的参考价值。

mysqldump -u -p --tables

--tables 后面个表名称就是要单独备份

恢复就是和正常恢复一样就行了
参考技术A phpmyadmin中点要导出的表然后选导出就可以了

如何优雅的备份MySQL数据?

  1. 为什么要备份数据
    先说一下为什么需要备份MySQL数据?

一句话总结就是:为了保证数据的安全性。

如果我们把数据只存储在一个地方,如果物理机器损坏,会导致数据丢失,无法恢复。

还有就是我们每次手动修改线上数据之前,为了安全起见,都需要先备份数据。防止人为的误操作,导致弄脏数据或弄丢数据。

  1. 怎样备份MySQL数据?
    想要快速简单粗暴备份MySQL数据,可以使用mysqldump命令:

备份test数据库

mysqldump -uroot -p test > backup.db
但是这样备份的可能包含脏数据,比如在我们备份数据的过程中,有个下单的操作正在执行。

下单之后,还没有来得及扣款,就开始执行备份数据的命令,就会出现脏数据。

下单,保存订单表
备份数据
扣款
3. 怎么安全的备份数据?
mysqldump命令也提供了以事务的形式备份的参数:

开启一个事务备份test数据库

mysqldump -uroot -p --single-transaction test > backup.db
开启事务后,会跟正常业务操作产生锁资源竞争,可能会阻塞其他的业务操作,严重的可能会导致服务宕机,所以备份操作尽量在业务低峰期执行。

还有一个问题,只有InnoDB引擎支持事务命令,对于不支持的事务MyISAM引擎,备份数据的时候怎么保证数据的安全性呢?

有一个粗暴的办法就是设置全库只读,禁止写操作,这样备份的时候不就能保证数据安全性啦。

先用命令查看一下数据库的只读状态:

show variables like ‘read_only’;

OFF表示只读模式关闭,ON表示开启只读模式。

set global read_only=1;

这样设置其实是非常危险的,如果客户端连接断开,整个数据库也会一直处于只读模式,无法进行写操作。

更推荐的办法是设置全局锁 FTWRL(flush tables with read lock)。

设置全局锁,禁止写操作

flush tables with read lock;

释放锁

unlock tables;
设置全局锁之后,如果客户端断开,会自动释放锁,更安全。

  1. 怎么恢复数据?
    通过备份文件恢复数据也非常简单:

把备份文件数据导入到test数据库

mysqldump -uroot -p test < backup.db

以上是关于mysql备份数据库时怎样只备份一个数据库中的其中几张表的数据,覆盖时只覆盖这几张表的内容的主要内容,如果未能解决你的问题,请参考以下文章

在excel的sheet1中输入数据,怎样同步备份到sheet2中,且sheet1的数据更新时,sheet2的备份只新增而不覆盖

怎样备份mysql数据的一个表 而不是整个数据库

怎样在sql sever备份中恢复某一张表中的数据?

怎样备份/还原MySQL数据库 之 MySQL Workbench

MySQL全备份如何只恢复一个库或者一个表

从 hsqldb 备份中仅导入特定行