索引是什么

mysql官方对索引的定义为:索引(Index)是帮助MySQL高效获取数据的数据结构。

可以得到索引的本质:索引是数据结构,索引的目的是提高查询效率,可以类比英语新华字典,根据目录定位词语

如果没有目录呢,就需要从A到Z,去遍历的查找一遍,一个一个找和直接根据目录定位到数据,差的就是天壤之别

索引底层数据结构

数据库除了存储数据本身之外,还维护着一个满足特定查找算法的数据结构,这些结构以某种方式指向数据,这样就可以基于这些数据结构实现高效查找算法。这种结构就是索引,MySQL中索引是B+树实现的,每个索引都对应一棵B+树

索引的优势

提高数据检索效率,降低数据库IO成本

通过索引列对数据进行排序,降低数据排序成本,降低了CPU消耗

索引的劣势

一个索引都为对应一棵B+树,树中每一个节点都是一个数据页,一个页默认会占用16KB的存储空间,所以一个索引也是会占用磁盘空间的。(空间的代价)

索引是对数据的排序,当对表中的数据进行增、删、改操作时,都要维护修改内容涉及到的B+树索引。所以在进行这些操作时需要额外的时间进行一些记录移动,页面分裂、页面回收等操作来维护索引(时间上的代价)

索引语法

以test_user表为例,建表sql如下

CREATE TABLE`test_user` (

`id`int(11) NOT NULL AUTO_INCREMENT COMMENT '主键id',

`user_id` varchar(36) NOT NULL COMMENT '用户id',

`user_name` varchar(30) NOT NULL COMMENT '用户名称',

`phone`varchar(20) NOT NULL COMMENT '手机号码',

`lan_id`int(9) NOT NULL COMMENT '本地网',

`region_id`int(9) NOT NULL COMMENT '区域',

`create_time`datetime NOT NULL COMMENT '创建时间',PRIMARY KEY(`id`),KEY `idx_user_id` (`user_id`)

) ENGINE=InnoDB AUTO_INCREMENT=1010001 DEFAULT CHARSET=utf8mb4;

1.查看索引:SHOW INDEX FROM table_nameG

SHOW INDEX FROM test_user;

2.删除索引:DROP INDEX [indexName] ON mytable;

DROP INDEX idx_user_id ON test_user;

3.创建索引 alter tableName add [unique] index [indexName] on (columnName (length) )

ALTER TABLE test_user ADD INDEX idx_user_id(user_id);

哪些情况需要建索引

主键自动建立唯一索引

频繁作为查询的条件的字段应该创建索引

查询中与其他表关联的字段,外键关系建立索引

频繁更新的字段不适合创建索引:因为每次更新不单单是更新了记录还会更新索引,加重IO负担

Where条件里用不到的字段不创建索引

单间/组合索引的选择问题(在高并发下倾向创建组合索引)

查询中排序的字段,若通过索引去访问将大大提高排序的速度

查询中统计或者分组字段

哪些不适合建索引

表记录太少

经常增删改的表

数据重复且分布平均的表字段,如果某个数据列包含许多重复的内容,为它建立索引就没有太大的实际效果。

索引实战

我们在test_user表中有100万数据

优化一:使用全部索引

1.不加索引,关闭缓存查一条数据

SELECT SQL_NO_CACHE * FROM `test_user` WHERE phone='15190427892' AND lan_id=317 AND region_id=92

2.加一条复合索引

ALTER TABLE test_user ADD INDEX idx_phone_lan_region(phone,lan_id,region_id);

再查一次,看结果

可以看到,加了索引以后,查询效率提高了很多

这里我们建立的复合索引包含的3个字段,查询的时候全部用到了,而且where中的条件严格按照索引顺序,这样查询效率是最高的

我们使用EXPLAIN关键字看一下

优化二:最左前缀法则

我们把上面那个例子的第一个插件条件删掉

EXPLAIN SELECT SQL_NO_CACHE * FROM `test_user` WHERE lan_id=317 AND region_id=92;

我们使用EXPLAIN关键字看一下

因此,我们得出结论:如果建立的是复合索引,索引的顺序要按照建立时的顺序,即从左到右,如:a->b->c(和 B+树的数据结构有关)

无效索引举例

a->c:a 有效,c 无效

b->c:b、c 都无效

c:c 无效

优化三:不要对索引做以下处理

计算,如:+、-、*、/、!=、<>、is null、is not null、or

函数,如:sum()、round()等等

手动/自动类型转换,如:id = "1",本来是数字,给写成字符串了

我们以!=为例演示,我们使用EXPLAIN关键字看一下

优化四:索引不要放在范围查询右边

比如复合索引:a->b->c,当 where a="" and b>10 and c="",这时候只能用到 a 和 b,c 用不到索引,因为在范围之后索引都失效(和 B+树结构有关)

如下

EXPLAIN SELECT SQL_NO_CACHE * FROM `test_user` WHERE phone='15190427892' AND lan_id>317 AND region_id=92;

我们使用EXPLAIN关键字看一下

我们把最后一个条件删除,再看一下

优化五:减少 select * 的使用

select *会查询很多不必要的字段,造成不必要的网络传输和IO消耗

优化六:like 模糊搜索

失效情况

like "%张三%"

like "%张三"

解决方案

使用复合索引,即 like 字段是 select 的查询字段,如:select name from table where name like "%张三%"

使用 like "张三%"

优化七:order by 优化

当查询语句中使用 order by 进行排序时,如果没有使用索引进行排序,会出现 filesort 文件内排序,这种情况在数据量大或者并发高的时候,会有性能问题,需要优化。

filesort 出现的情况举例

order by 字段不是索引字段

order by 字段是索引字段,但是 select 中没有使用覆盖索引,如:select * from staffs order by age asc;

order by 中同时存在 ASC 升序排序和 DESC 降序排序,如:select a, b from staffs order by a desc, b asc;

order by 多个字段排序时,不是按照索引顺序进行 order by,即不是按照最左前缀法则,如:select a, b from staffs order by b asc, a asc;

如下情况没有索引

filesort 文件内排序会在内存开辟一块空间,然后把数据复制了一份放到这个空间内,再进行排序,这个是很影响性能的

我们可以为这个字段建一个索引

ALTER TABLE test_user ADD INDEX idx_create_time(create_time);

索引层面解决方法

使用主键索引排序

按照最左前缀法则,并且使用覆盖索引排序,多个字段排序时,保持排序方向一致

在 SQL 语句中强制指定使用某索引,force index(索引名字)

不在数据库中排序,在代码层面排序

优化八:group by

其原理也是先排序后分组,其优化方式可参考order by。where高于having,能写在where限定的条件就不要去having限定了。

以上就是MySQL索引介绍和实战的全部内容。

mysql索引linke和等于_MySQL索引介绍和实战相关推荐

  1. mysql索引linke和等于_MySQL索引怎么用?秒懂只需四个点!

    一.前言 在MySQL中进行SQL优化的时候,经常会在一些情况下,对MySQL能否利用索引有一些迷惑. 譬如: 1.MySQL 在遇到范围查询条件的时候就停止匹配了,那么到底是哪些范围条件? 2.My ...

  2. mysql索引linke和等于_MySQL索引的学习

    MySQL索引的学习 关于使用mysql索引的好处,合理的设计并使用mysql索引能够有效地提高查询效率.对于没有索引的表,单表查询可能几十万数据就是平静,在大型网站单日可能会产生几十万甚至几百万的数 ...

  3. mysql索引linke和等于_MySQL之SQL优化详解(三)

    摘要: 致索引失效而转向全表扫描存储引擎不能使用索引中范围条件右边的列mysql在使用不等于(!=或者<>)的时候无法使用索引会导致全表扫描isnull,isnotnull也无法使用索引l ...

  4. mysql 搜索不等于_Mysql索引分类

    在绝大多数情况下,Mysql索引都是基于B+树的,而索引可以提高数据查询的效率.但是Mysql是如何利用B+树进行查询的呢?索引的作用只是提高查询效率吗? Mysql中的B+Tree索引 假设有一张教 ...

  5. mysql介绍索引类型的章节_mysql索引总结--mysql索引类型以及创建的详细介绍

    关于MySQL索引的好处,如果正确合理设计并且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL就是一个人力三轮车.对于没有索引的表,单表查询可能几十万数据就是瓶颈,而通常大型 ...

  6. mysql索引linke和等于_10分钟让你明白MySQL是如何利用索引的

    1.前言 在MySQL中进行SQL优化的时候,常常会在一些状况下,对MySQL可否利用索引有一些迷惑.数据库 譬如:ide MySQL 在遇到范围查询条件的时候就中止匹配了,那么究竟是哪些范围条件? ...

  7. mysql索引是什么 优点和缺点_MySQL索引优缺点、使用原则及种类介绍

    一.索引简介 1.索引简介 索引(Index)是帮助MySQL高效获取数据的数据结构. 在MySQL中,索引属于存储引擎级别的概念,不同存储引擎对索引的实现方式是不同的.MyISAM和InnoDB存储 ...

  8. mysql索引背后的数据结构_MySQL索引背后的数据结构及算法原理

    摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎 对索引的支持也各不相同,因此MySQL数据库支持多种索引类型,如B ...

  9. mysql是如何管理数据结构_MySQL索引背后的数据结构和原理

    这是我看到的一篇博客,讲得非常详细,分享给大家:http://blog.codinglabs.org/articles/theory-of-mysql-index.html Abstract: 本文以 ...

最新文章

  1. sql 优化 tips
  2. php ziparchive 压缩文件,php使用ZipArchive压缩打包文件
  3. 【Silverlight】Bing Maps开发应用与技巧三:Bing Maps Silverlight Control的离线开发
  4. war3必须安装的游戏组件_在单独的WAR组件中对SPA资源和API实现进行分区
  5. 前端学习(2165):vuecli3配置文件的修改和查看
  6. 【jvm】java jvm 参数调优 列表
  7. linux2019内核版本发布,新兴的桌面发行版 Septor Linux 发布 2019 版
  8. 数据结构上机实践第14周项目1(2) - 验证算法(分块查找)
  9. RPC和MQ对比及其适用/不适用场合
  10. Nginx Upload Module 上传模块
  11. 批处理(bat)文件中输出中文乱码怎么办?
  12. 关于PHP自定义采集图片脚本
  13. 【产品】外壳防护等级(IP代码)
  14. 网关与路由器关系介绍
  15. 哪里买linux虚拟主机的,怎样购买虚拟主机
  16. Windows起一个Docker镜像——起起起起起~不~来~
  17. 【uView】picker 地区选择
  18. TVM User Tutorial -- Quick Start Tutorial for Compiling Deep Learning Models
  19. CHIL-SQL-JOIN
  20. URL 链接中 井号#、问号?、连接符 分别有什么作用?

热门文章

  1. Linux高并发服务器开发---笔记2(多进程)
  2. 异常记录---Error creating bean with name 'sqlSessionFactory'
  3. 新硬盘怎么装系统分区?
  4. 网站繁简切换的JS遇到的一个BUG
  5. 常见的web中间件java框架漏洞总结
  6. Spring Cache,从入门到真香
  7. 金融组织做规模化敏捷怎么划小队,一文讲清
  8. 计算机联到同一个局域网,两台电脑连接同一个wifi算是局域网么
  9. DPI、PPI、DP、PX 的详细计算方法及算法来源是什么
  10. python 小游戏 《孙悟空大战白骨精》