mysql聚簇索引与非聚簇索引
来源:互联网 发布:win10软件小助手 编辑:程序博客网 时间:2024/06/05 09:36
看了好多博客,感觉说的有点笼统,那么我就更笼统的说一下mysql的聚簇索引与非聚簇索引吧
首先说一下什么是mysql索引,有什么用。
MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度。
索引分单列索引和组合索引。单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引。组合索引,即一个索引包含多个列。
创建索引时,你需要确保该索引是应用在 SQL 查询语句的条件(一般作为 WHERE 子句的条件)。
实际上,索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。
上面都在说使用索引的好处,但过多的使用索引将会造成滥用。因此索引也会有它的缺点:虽然索引大大提高了查询速度,同时却会降低更新表的速度,如对表进行INSERT、UPDATE和DELETE。因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。
建立索引会占用磁盘空间的索引文件。
上边是从菜鸟教程中摘录出来的,足够理解什么是索引了,下面开始正题,什么是聚簇索引,什么是非聚簇索引
innodb存储引擎创建的索引是非聚簇索引
innodb的主索引文件上 直接存放该行数据,称为聚簇索引,次索引指向对主键的引用
myisam中,主索引和次索引,都指向物理行(磁盘位置).
注意: innodb来说,
1: 主键索引 既存储索引值,又在叶子中存储行的数据
2: 如果没有主键,则会Unique key做主键
3: 如果没有unique,则系统生成一个内部的rowid做主键.
4: 像innodb中,主键的索引结构中,既存储了主键值,又存储了行数据,这种结构称为”聚簇索引”
聚簇索引
优势: 根据主键查询条目比较少时,不用回行(数据就在主键节点下)
劣势: 如果碰到不规则数据插入时,造成频繁的页分裂.
C) 聚簇索引的页分裂过程
http://blog.csdn.net/lijiaz5033/article/details/50129723
- mysql聚簇索引与非聚簇索引
- MySQL索引:聚簇索引与非聚簇索引的区别
- MySQL索引:聚簇索引与非聚簇索引的区别
- MySQL 聚簇索引 和 非聚簇索引
- MySQL 聚簇索引和非聚簇索引
- mysql中的索引(聚簇索引和非聚簇索引)
- mysql聚簇索引和非聚簇索引以及二级索引
- 聚簇索引与非聚簇索引
- 聚簇索引与非聚簇索引
- 聚簇索引与非聚簇索引
- 聚簇索引与非聚簇索引
- 聚簇索引与非聚簇索引
- 什么是聚簇索引与非聚簇索引
- [MySQL] 索引与性能(2)- 聚簇索引
- 聚簇索引、非聚簇索引、覆盖索引
- 聚簇索引、非聚簇索引、覆盖索引
- mysql 优化(3)聚簇索引和非聚簇索引
- Mysql聚簇索引和非聚簇索引原理(数据库)
- 二叉树怎么打印根节点到指定节点的路径及两个节点之间的路径
- 第二章 线性表(链表的建立与合并)
- react-table组件入门和在IE11上遇到的坑
- 10.20mysql优化以及修改权限
- LeetCode 1. Two Sum
- mysql聚簇索引与非聚簇索引
- Javascript计算器(一)-基本功能实现
- Python 错误和异常
- 【编译原理】词法分析(二)
- 探索者 机械篇
- Python学习---用户输入和while循环
- 树上差分
- 对数据库的简单操作
- HDU4825 Xor Sum(Trie树,二进制)