我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL索引

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL索引

MySQL索引[数据库教程]

排好序快速查找的数据结构就是索引

提高检索效率,降低数据库对IO成本;降低数据排序,减少cpu消耗

单值索引:一个索引包含单个列,一个表可以有多个单值索引

唯一索引:索引值必须唯一,但允许有空值

复合索引:一个索引包含多个列

创建索引

CREATE [UNIQUE](唯一) INDEX  indexname(索引名称) ON tablename(表名) (columnname(length)字段和类型)  

该命令可以添加普通索引或唯一索引[UNIQUE]

或者

ALTER TABLE tablename ADD PRIMARY KEY (columnname_list)                          ---主键索引

ALTER TABLE tablename ADD  INDEX  UNIQUE  indename(columnname_list)     ---唯一索引

ALTER TABLE tablename ADD  INDEX  indename(columnname_list)                      ---普通索引

ALTER TABLE tablename ADD  INDEX  FULLTEXT indename(columnname_list)   ---全文索引

删除索引

DROP INDEX [indexname]  ON table

查看索引

SHOW INDEX FROM  table 

  • 主键自动创建索引
  • 频繁作为查询条件的字段
  • 连表关联的字段,外键关系创建索引
  • 高并发下创建复合索引
  • where字段
  • 排序的字段
  • 查询中统计或分组的字段

如果表记录太少,经常增删改的表,某列字段重复数据较多就不要建立索引

  1.  索引有多列时,遵循左前法则;顺序从左开始且不要跳过中间的索引,否则索引失效全盘扫描(带头大哥不能死,中间兄弟不能断)
  2. 不要再索引列上做任何操作,包括计算、函数、自动或者手动类型转换,否则导致索引失效(索引列上无计算)
  3. 范围条件查询之后的索引全部失效,使用范围查询时,有时会使用索引,有时会失效,这是因为使用范围条件的数据量有一定的范围(范围之后全失效)
  4. 索引列尽量和查询列一致,减少select *
  5. 使用“<>”或“!=”导致索引失效
  6. is null,is not null也会导致索引失效
  7. like的“%”在右边不会导致索引失效;查询的列匹配索引列,使用like ‘%xxx%’索引不会失效(like%加右边
  8. 字符串不加单引号或导致索引失效(字符串里有引号)
  9. or用来连接时导致索引失效,但是可以把or用union all代替
  • 保证被驱动表的join字段已经被索引
  • left join 时,选择小表作为驱动表,大表作为被驱动表
  • inner join 时,mysql会自己帮你把小结果集的表选为驱动表
  • 子查询尽量不要放在被驱动表,有可能使用不到索引
  • 在使用"in"时,用大表驱动小表,"exists"时用小表驱动大表
  • ORDER BY子句,尽量使用Index方式排序,避免使用FileSort方式排序
  • 尽可能在索引列上完成排序操作,遵照索引建的最佳左前缀
  • where子句中如果出现索引的范围查询(即explain中出现range)会导致order by 索引失效。
  • group by实质是先排序后进行分组,遵照索引建的最佳左前缀
  • where高于having,能写在where限定的条件就不要去having限定了。
  • 当无法使用索引列,增大max_length_for_sort_data参数的设置+增大sort_buffer_size参数的设置
  • 尽量不要使用 distinct,可以考虑分组去重

MySQL索引

原文:https://www.cnblogs.com/-zzc/p/13618841.html

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL索引

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

ElasticSearch索引 VS MySQL索引

这段时间在维护产品的搜索功能,每次在管理台看到 elasticsearch 这么高效的查询效率我都很好奇他是如何做到的。

MySQL索引:B+树索引

MySQL索引:B+树索引B+树索引是传统意义上的索引,这是目前关系型数据库系统中查找最为常用和最为有效的索引。B+树索引的构造类似于二叉树,根据键值快速找到数据B树B+树是由B树演化而来的,在了解B+树之前,我们需要对B树有一点认知。B树全称Balance-
MySQL索引:B+树索引
2021-09-01

[MySQL]MySQL索引

[MySQL]MySQL索引 文章目录 [MySQL]MySQL索引1. 索引的概念2. 认识磁盘磁盘的内部结构磁盘中的一个盘片结构定位扇区磁盘随机访问与连续访问 3. MySQL与磁盘交互的基本单位4. 建立共识5. 索引的
2023-08-17

MySQL 索引

索引的概念不使用索引,要操作某些行时,需要遍历遍历整张表来找到匹配的行,很花时间,且有点耗资源。书:目录=>快速定位到指定章节,不用一页一页地找数据库:索引=>快速定位到指定记录,不用遍历数据表去找,索引相当于数据表的目录  索引的优缺点提高查询效率,尤其是记
MySQL  索引
2018-11-30

Mysql 索引

所谓聚簇索引,就是将索引和数据放到一起,找到索引也就找到了数据,B+树索引就是一种聚簇索引,而非聚簇索引就是将数据和索引分开,查找时需要先查找到索引,然后通过索引回表找到相应的数据。InnoDB有且只有一个聚簇索引,而MyISAM中都是非聚簇索引。 更多详细索
2018-06-24

MySQL索引

什么是索引?排好序快速查找的数据结构就是索引索引作用提高检索效率,降低数据库对IO成本;降低数据排序,减少cpu消耗索引类型单值索引:一个索引包含单个列,一个表可以有多个单值索引唯一索引:索引值必须唯一,但允许有空值复合索引:一个索引包含多个列基本语法创建索引
MySQL索引
2015-09-15

Mysql-索引

先创建表mysql> CREATE TABLE test( -> id INT, -> username VARCHAR(16), -> city VARCHAR(16), -> age INT -> );1.普通索引是最基本的索
Mysql-索引
2014-05-24

MySQL索引篇

目录 MySQL索引一、怎么知道一条SQL语句有没有使用索引?二、如何排查慢查询三、索引失效以及为什么失效四、索引为什么能提高查询性能五、为何选择B+树而不是B树六、索引分类七、什么时候创建以及什么时候不需要索引八、索引优化
2023-08-19

mysql之索引

哪些情况需要创建索引 主键自动建立唯一索引 频繁作为查询条件的字段应该创建索引(where 后面的语句) 查询中与其它表关联的字段,外键关系建立索引 单键/组合索引的选择问题,who?(在高并发下倾向创建组合索引) 查询中排
mysql之索引
2016-10-12

mysql的索引

什么是索引帮助Mysql高效获取数据的数据结构索引就是数据结构类似新华字典的索引目录,可以通过索引目录快速查到你想要的字排好序的快速查找数据为什么要建立索引提高查询效率 没有排序之前一个一个往后找 通过索引进行排序之后,可以直接定义到想要的位置排好序的快速查找
mysql的索引
2018-07-12

MySQL 聚集索引和二级索引

Clustered and Secondary Indexes(聚集索引和二级索引)Every InnoDB table has a special index called the clustered index where the data for the
MySQL 聚集索引和二级索引
2022-03-11

MySQL btree索引与hash索引区别

在MySQL中,大多数索引(如 PRIMARY KEY,UNIQUE,INDEX和FULLTEXT)都是在BTREE中存储,但使用memory引擎可以选择BTREE索引或者HASH索引,两种不同类型的索引各自有其不同的使用范围。B树索引具有
2022-05-14

【MySQL】MySQL索引详解

Mysql索引 0.写在前面1.为什么要使用索引2.常见的索引模型3.索引维护4.回表?举例子。 0.写在前面 文章中包含了: 1.什么是索引 2.索引的数据结构,以及各自的使用场景 3.为什么要设置主键自增? 4.基于主键
2023-08-16

编程热搜

目录