mysql 索引( mysql index )
来源:互联网 发布:淘宝apass会员是什么 编辑:程序博客网 时间:2024/05/21 06:13
以下是查阅《mysql_administrators_bible》的摘录和总结
索引 mysql index
索引是一种数据结构,可以是B-tree, R-tree, 或者 hash 结构。其中R-tree 常用于查询比较接近的数据;B-trees适合用于查找某范围内的数据,可以很快的从当前数据找到下条数据;hash结构则适用于随机访问的场合,查找每条数据的时间几乎相同。显然,若要查找某个时间段的数据,用B-tree结构要比hash结构快好多。
优化查询的有效方法是为经常查询的字段建立索引,如无索引查询数据时,会遍历整张表(多么恐怖啊);若有了索引查找会容易很多。当进行 UPDATE, DELETE, 以及 INSERT 操作时,mysql会自动更新索引信息。
1.创建和删除索引( Creating and dropping indexes )
创建:
PS:当用 create index 创建索引时,必须指定索引的名字,否则mysql会报错;
用 ALTER TABLE 创建索引时,可以不指定索引名字,若不指定mysql会自动生成索引名字
建立索引时,若不想用存储引擎的默认索引类型,可以指定索引的类型:
删除:
2.索引类型
BTREE 适合连续读取数据
RTREE 适合根据一条数据找附近的数据
HASH 适合随机读取数据
FULLTEXT
SPATIAL
查看某个表中存在的索引类型
3.索引冗余
如果两个或者多个索引包含了相同的索引信息,那么就存在索引冗余。
不同类型的索引有不同的索引冗余判断:
(1) SPATIAL 索引
SPATIAL 只能是一个简单索引,不能说复合索引;存在冗余的情况是同一个字段有两个索引。
(2) FULLTEXT 索引
若一个FULLTEXT索引是另一个索引的子集(不考虑字段顺序),则存在冗余。
例如: 表中包含如下两个索引
■ (field1)
■ (field1, field2)
(3) HASH 索引
若一个索引在不考虑字段顺序的情况下,索引字段相同,则存在冗余。
例如:表中包含如下两个索引
■ (field1, field2, field3)
■ (field1, field3, field2)
(4) BTREE 索引
若一个索引是另一个索引的子集(考虑字段顺序),则存在冗余。
例如:表中包含如下两个索引
■ (field2)
■ (field2, field1)
PS:若两个或多个索引有相同的索引字段和字段顺序,但是有不同的索引类型,这样的索引是不冗余的。因为每种索引类型有自己的索引值。
- mysql 索引( mysql index )
- mysql 索引( mysql index )
- mysql 索引( mysql index )
- mysql 索引(index)
- MySQL index索引问题
- mysql创建index索引
- mysql 索引(index)
- mysql index索引
- mysql之index(索引)
- mysql索引优化方法 index
- MySQL索引(index)专题
- 关于MySQL索引index杂谈
- 关于MySQL索引index杂谈
- 关于MySQL索引index杂谈
- mysql 操作索引FORCE INDEX
- mySQL中索引index详解
- mysql索引index相关命令
- mysql force Index 强制索引 忽略索引 IGNORE INDEX
- 白话CMMI,^_^,通俗易懂
- java virtual machine(java虚拟机的运行机制)?
- Flex字体篇——动态嵌入字体(按需嵌入)
- EDLinux 2----细数Linux的挂载及其他
- 移动硬盘无法访问,打开提示”文件或目录损坏且无法读取”的处理方法
- mysql 索引( mysql index )
- Cisco VPN 配置命令详细解释
- 4 进程调度
- 一个md5破解的网站。。
- PKU1611--并查集Kruskar算法实现最小生成树源码
- 第一次发文
- Dell1464笔记本安装Win7旗舰版和XP经历
- 网页打开速度慢的原因及N种解决方法
- ref 和 out关键字的用法