1、MySQL中的索引

在MySQL,索引是由B 树实现的,B 是一种与B树十分类似的数据结构。

形如下面这种:

mysql的索引存储与划分(MySQL中的索引和其两种引擎)(1)

其结构特点

(1)有n课子树的结点中含有n个关键码。

(2)非根节点子节点数: ceil(m/2)<= k <= m(ceil是天花板函数的意思,也就是向上取整,比如ceil(1.2)=2 ),m为该B 树的阶数。根节点最少有两个子节点,最多同样为m个。

(2)叶子节点包含了全部关键码的信息,及指向含有这些关键码记录的指针。并且叶子节点根据关键码的大小自小至大的顺序链接,叶子节点有相邻结点的指针。

(3)所有的非叶子节点(B 树中也称内部结点,索引节点)可以看成索引部分,都不存储数据,只存储索引,结点中仅含有其子树根节点中最大(或者最小)的关键码,数据都存储在叶子节点中。

问题:为什么索引不适用B树而是B 树实现?

B 树比B树的优点:

问题:为什么不采用效率更高的哈希查找?

采用B 树索引与哈希索引的比较:

哈希索引能以 O(1) 时间进行查找,但是只支持精确查找,无法用于部分查找和范围查找,无法用于排序与分组。B 树索引支持大于小于等于查找,范围查找。哈希索引遇到大量哈希值相等的情况后查找效率会降低。哈希索引不支持数据的排序。

2、MySQL的两种数据库引擎

(1)InnoDB(in-no-db)

(2)MyISAM(mai-ai-zem)

它提供高速存储和检索(MyISAM强调的是性能,每次查询具有原子性,其执行速度比InnoDB更快),以及全文搜索能力。如果表比较小,或者是只读数据(有大量的SELECT),还是可以使用MyISAM。InnoDB 支持事务,并发情况下有很好的性能,基本可以替代MyISAM。

热备份和冷备份

热备份:在数据库运行的情况下备份的方法。

优点:可按表或用户备份,备份时数据库仍可使用,可恢复至任一时间点。但是不能出错。

冷备份:数据库正常关闭后,将关键性文件复制到另一位置的备份方式。

优点:操作简单快速,恢复简单。

3、主从复制

主从复制(Replication)是指数据可以从一个MySQL数据库主服务器复制到一个或多个从服务器,从服务器可以复制主服务器中的所有数据库或者特定的数据库,或者特定的表。默认采用异步模式。

实现原理:

4、关系型数据库和非关系型数据库

关系型数据库(如Oracle,MySQL):表和表、表和字段、数据和数据存在着关系,它通过数据、关系和对数据的约束三者组成的数据模型来存放和管理数据。优点:

缺点

非关系数据库(如Redis和MangDB)非关系型数据库严格上不是一种数据库,而是一种数据结构化存储方法的集合,可以是文档或者键值对等。为了处理大量数据,非关系数据库设计之初就是为了去替代关系型数据库。优点

缺点

,