什么是MySQL数据库?MySQL 数据库备份与恢复

4747 626 2023-06-15

本文讲述了什么是MySQL数据库?MySQL 数据库备份与恢复

MySQL经常和“数据库”连在一起读,这很容易对新手造成误解,认为MySQL就是一个数据库,其实不是这样,MySQL是数据库的集合,MySQL里面有很多数据库,那么数据是直接存在数据库里的吗?并不,数据库底下还有一个叫作数据表的存储单元,数据表里面才存储数据。

打个比方,好比一座大图书馆,就是MySQL,图书馆里面分南库,北库,这就是数据库,每个库里面的书都是放在书架上的,书架就是数据表,而放在书架上的很多本书,就是数据。这么说,大家应该理解了吧,所以按大小顺序排个序就应该是,MySQL>数据库>数据表>数据。

MySql数据库是开放源代码的关系型数据库。目前,它可以提供的功能有:支持sql语言、子查询、存储过程、触发器、视图、索引、事务、锁、外键约束和影像复制等。

同*** 和***等大型数据库系统一样,MySql也是客户/服务器系统并且是单进程多线程架构的数据库。

MySql区别于其它数据库系统的一个重要特点是支持插入式存储引擎

那么什么是存储引擎呢?

存储引擎说白了就是如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操作此表的类型)。

在*** 和***等数据库中只有一种存储引擎,所有数据存储管理机制都是一样的。 而MySql数据库提供了多种存储引擎。用户可以根据不同的需求为数据表选择不同的存储引擎,用户也可以根据自己的需要编写自己的存储引擎。

MySql中有哪些存储引擎?

MyISAM:这种引擎是mysql最早提供的。

这种引擎又可以分为静态MyISAM、动态MyISAM 和压缩MyISAM三种:

静态MyISAM:如果数据表中的各数据列的长度都是预先固定好的,服务器将自动选择这种表类型。因为数据表中每一条记录所占用的空间都是一样的,所以这种表存取和更新的效率非常高。当数据受损时,恢复工作也比较容易做。

动态MyISAM:如果数据表中出现varchar、xxxtext或xxxBLOB字段时,服务器将自动选择这种表类型。相对于静态MyISAM,这种表存储空间比较小,但由于每条记录的长度不一,所以多次修改数据后,数据表中的数据就可能离散的存储在内存中,进而导致执行效率下降。同时,内存中也可能会出现很多碎片。因此,这种类型的表要经常用optimize table 命令或优化工具来进行碎片整理。

压缩MyISAM:以上说到的两种类型的表都可以用myisamchk工具压缩。这种类型的表进一步减小了占用的存储,但是这种表压缩之后不能再被修改。另外,因为是压缩数据,所以这种表在读取的时候要先时行解压缩。

但是,不管是何种MyISAM表,目前它都不支持事务,行级锁和外键约束的功能。

MyISAM Merge引擎:这种类型是MyISAM类型的一种变种。

合并表是将几个相同的MyISAM表合并为一个虚表。常应用于日志和数据仓库

InnoDB: InnoDB表类型可以看作是对MyISAM的进一步更新产品,它提供了事务、行级锁机制和外键约束的功能。

memory(heap): 这种类型的数据表只存在于内存中。

它使用散列索引,所以数据的存取速度非常快。 因为是存在于内存中,所以这种类型常应用于临时表中。

archive: 这种类型只支持select 和 insert语句,而且不支持索引。

常应用于日志记录和聚合分析方面。

当然MySql支持的表类型不止上面几种。

数据库备份时把把数据库的结构,包括数据、约束、索引、视图等全部另存为一个文件。

使用 mysqldump 备份的语句:

mysqldump 是 MySQL 用于备份数据库的实用程序。它主要产生一个 SQL 脚本文件,其中包含从头重新创建数据库所必需的命令 CREATE TABLE INSERT 等。

使用 mysqldump 备份的语句:

image.png

mysqldump 是一个备份工具,因此该命令是在终端中执行的。

数据库恢复是在备份为前提的情况下进行的,先使用命令新建一个空的数据库 test:

image.png

再次 Ctrl+D 退出 MySQL,然后输入语句进行恢复,把刚才备份的 bak.sql 恢复到 test 数据库:

image.png

我们输入命令查看 test 数据库的表,便可验证是否恢复成功:

image.png

上文就是小编为大家整理的什么是MySQL数据库?MySQL 数据库备份与恢复

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:从输入 SQL 到返回数据,到底发生了什么?
下一篇:数据库自动化运维实践,基于开源软件自主开发自动化运维系统
相关文章