大家好,如果您还对下载网站源码分享怎么还原数据库不太了解,没有关系,今天就由本站为大家分享下载网站源码分享怎么还原数据库的知识,包括下载网站源代码的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!
本篇文章将主要讲解MySQL数据库数据备份与恢复相关知识,主要聚焦于逻辑备份,介绍mysqldump工具的使用以及恢复方法。
这里简单讲下物理备份和逻辑备份的概念:
物理备份:备份数据文件,转储数据库物理文件到某一目录。物理备份恢复速度比较快,但占用空间比较大,MySQL中可以用xtrabackup工具来进行物理备份。
逻辑备份:对数据库对象利用工具进行导出工作,汇总入备份文件内。逻辑备份恢复速度慢,但占用空间小,更灵活。MySQL中常用的逻辑备份工具为mysqldump。
1.备份全部数据库
若想用mysqldump备份整个实例,可以使用–all-databases或-A参数:
mysqldump-uroot-pxxxxxx–all-databases>/tmp/all_database.sql\nmysqldump-uroot-pxxxxxx-A>/tmp/all_database.sql\n
2.备份部分数据库
有的时候我们会遇到只需要备份某些库的需求,这个时候我们就可以使用–databases或-B参数了,该参数后面跟数据库名称,多个数据库间用空格隔开。
mysqldump-uroot-pxxxxxx–databasestestdb1testdb2>/tmp/testdb.sql\nmysqldump-uroot-pxxxxxx-Btestdb1testdb2>/tmp/testdb.sql\n
3.备份部分表
平时我们也会有备份部分表的需求,比如说在表变更前做个备份,那么我们可以这样做:
备份多张表\nmysqldump-uroot-pxxxxxxtestdbtb1tb2tb3>/tmp/tb.sql\n
4.备份单表的部分数据
有些时候一张表的数据量很大,我们只需要部分数据,那么该怎么办呢?这时候就可以使用–where选项了。where后面附带需要满足的条件。例如:我们只需要tb1表中create_time大于2019-08-01的数据,那么可以这样导出:
mysqldump-uroot-pxxxxxxtestdbtb1–where=”create_time>=’2019-08-0100:00:00′”>/tmp/tb1.sql\n
5.排除某些表导出
如果我们想备份某个库,但是某些表数据量很大或者与业务关联不大,这个时候可以考虑排除掉这些表,同样的,选项–ignore-table可以完成这个功能。
mysqldump-uroot-pxxxxxxtestdb–ignore-table=testdb.tb1>/tmp/testdb.sql\n
6.只备份结构或只备份数据
只备份结构的话可以使用–no-data简写为-d选项;只备份数据可以使用–no-create-info简写为-t选项。
mysqldump-uroot-pxxxxxxtestdb–no-data>/tmp/testdb_jiegou.sql\nmysqldump-uroot-pxxxxxxtestdb–no-create-info>/tmp/testdb_data.sql\n
7.备份中包含存储过程函数,事件
mysqldump备份默认是不包含存储过程,自定义函数及事件的。我们可以使用–routines或-R选项来备份存储过程及函数,使用–events或-E参数来备份事件。例如:我们想备份整个testdb库,包含存储过程及事件:
mysqldump-uroot-pxxxxxx-R-E–databasestestdb>/tmp/testdb.sql\n
8.以事务的形式备份
如果我们想在dump过程中保证数据的一致性,减少锁表,则可以用–single-transaction选项,这个选项对InnoDB的数据表很有用,且不会锁表。
mysqldump-uroot-pxxxxxx–single-transaction–databasestestdb>/tmp/testdb.sql\n
9.全量备份恢复
如果我们现在有昨天的全量备份,现在想整个恢复,则可以这样操作:
mysql-uroot-pxxxxxx</tmp/all_database.sql\n
10.从全量备份中恢复单库
可能有这样的需求,比如说我们只想恢复某一个库,但是我们有的是整个实例的备份,这个时候我们想到能不能从全量备份中分离出单个库的备份,答案是可以的,下面这个简单的shell可以帮到你哦:
sed-n’/^–CurrentDatabase:`testdb`/,/^–CurrentDatabase:`/p’all_databases.sql>testdb.sql\n用shell语法分离出创建表的语句及插入数据的语句后再依次导出即可完成恢复\n
总结:
本篇文章给出了在不同场景下的备份及恢复方法,可能生产中还会有更复杂的场景,需要大家灵活应变。
获取资料:
最后给大家分享一些学习资料,里面包括:(BATJ面试资料、高可用、高并发、高性能及分布式、Jvm性能调优、Spring源码,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多个知识点的架构资料)和Java进阶学习路线图。
免费领取方式:关注作者,私信关键词(666)即可
资料整理不易,请转发评论,最后,祝大家早日学有所成!
关于下载网站源码分享怎么还原数据库的内容到此结束,希望对大家有所帮助。
