mysql之聚簇索引
2015-09-08 16:09
501 查看
聚簇索引不是一个独立的索引类型,而是一种数据存储的方式。InnoDB使用B-Tree来实现聚簇索引,并把索引和数据存放在同一结构中。在有聚簇索引的表中,索引和行是存放在同一个叶子节点(B-Tree)中的。"聚簇"表示索引值相邻的行的存储位置一般也是相邻的——一般来说是这样,但在某些情况下不是。一张表只能有一个聚簇索引,因为同一份数据不可能出现两个地方。
聚簇索引(Clustered Index)和非聚簇索引 (Non- Clustered Index)
最通俗的解释是:聚簇索引的顺序就是数据的物理存储顺序,而对非聚簇索引的索引顺序与数据物理排列顺序无关。举例来说,你翻到新华字典的汉字“爬”那一页就是P开头的部分,这就是物理存储顺序(聚簇索引);而不用你到目录,找到汉字“爬”所在的页码,然后根据页码找到这个字(非聚簇索引)。
图中展示了一个聚簇索引的示例,需要注意的是:只有叶子节点才包括了数据行的值,非叶子节点只存了索引字段。
在某些DB实现中,可以选择按照哪个索引做聚簇,但是MySQL的所有存储都不支持这样——InnoDB只能按照主键做聚簇。
如果表中没有定义主键,InnoDB会选择一个“非空且有唯一性约束“的索引来做聚簇,如果没有这样的索引,则会定义一个不可见的主键,并以这个主键来聚簇。
聚簇索引(Clustered Index)和非聚簇索引 (Non- Clustered Index)
最通俗的解释是:聚簇索引的顺序就是数据的物理存储顺序,而对非聚簇索引的索引顺序与数据物理排列顺序无关。举例来说,你翻到新华字典的汉字“爬”那一页就是P开头的部分,这就是物理存储顺序(聚簇索引);而不用你到目录,找到汉字“爬”所在的页码,然后根据页码找到这个字(非聚簇索引)。
图中展示了一个聚簇索引的示例,需要注意的是:只有叶子节点才包括了数据行的值,非叶子节点只存了索引字段。
在某些DB实现中,可以选择按照哪个索引做聚簇,但是MySQL的所有存储都不支持这样——InnoDB只能按照主键做聚簇。
如果表中没有定义主键,InnoDB会选择一个“非空且有唯一性约束“的索引来做聚簇,如果没有这样的索引,则会定义一个不可见的主键,并以这个主键来聚簇。
相关文章推荐
- kettle gbk数据到utf8 mysql乱码问题解决
- skip-grant-tables:非常有用的mysql启动参数
- mysql操作 ubuntu-14.04.2-server-amd64
- mysql统计一个字段的多种状态
- mysql 查询语句
- ActiveReports如何使用MySQL数据库
- Ubuntu 安装mysql和简单操作
- Mysql innodb_flush_log_trx_commit 简单调优
- MySQL技术之旅--随意写在前面的话
- MySQL允许远程连接的设置总结
- mysql limit使用方法
- MySQL字符串函数substring:字符串截取
- MYSQL命令
- mysql主主关系配置
- MySQL索引类型&建立索引的时机&索引的不足之处
- 命令行修改MySQL数据库密码
- MySQL CMake参数说明手册
- MYSQL-统计查询
- mysqli
- 解决您配置文件中的设置 (空密码的 root) 与 MySQL 默认管理员账户对应。