1)用途、优缺点

用途:主要用于提高检索(排序)效率
优点:提高检索效率
缺点:增加新增、修改、删除删除索引的维护成本,需要增加额外的存在空间

---------------------------------------------------------------------------------------------------------------------------------

2)索引的分类

存储结构类型 

1)B-tree
有序可以用与等值匹配与范围查询,可以提高索引字段排序效率,创建删除变更索引效率稍低(需要考
虑索引排序,索引分裂等问题)。
mysql使用的是B+tree索引,B+tree不同于b-tree主要是在所有数据都只存放在叶子节点上(减少了非
叶子节点存在信息量,减少了树的整体高度),同时增加了顺序指针,每个叶子点上都存储了相邻叶子节
点的指针(范围查询效率功能)。2)Hash(仅仅Memory存储引擎)
无序只可以用于等值匹配(等值匹配效率高[需要高区分度]),无法使用部分索引,无法提高排序效率,
创建删除变更索引的成本优于B-tree索引。3)R-tree4)Full-index

应用类型

1)普通索引         idx_     开头
2)唯一索引         uniq_    开头
3)联合索引         union_   开头
4)全文索引         ft_      开头
5)函数索引(8之后) fc_      开头

聚簇索引与非聚簇索引

Innodb引擎B+Tree的叶子节点存储了整行数据的是主键索引,也被称之为聚簇索引,即将数据存储
与索引放到了一块,找到索引也就找到了数据。Innodb引擎主键索引即聚簇索引【避免回表查询,非聚簇索引只有在索引覆盖的场景下才不会回表】,
其他索引均为非聚簇索引。

---------------------------------------------------------------------------------------------------------------------------------

3)字段选取规范

主键自增索引(表中必须创建主键索引)

1)保证数据的唯一性
2)保证数据的有序性
3)减少索引分裂

字段查询频率高,字段区分度高,更新频率低(查询频率与区分度同样重要)

1)查询频率高的字段是创建索引的首要条件(保证有需求)
2)字段的区分度是是否创建索引的次要条件(保证有可行性)
3)字段的变更频率是创建索引的关键因素(保证无较大的附带伤害)

唯一性的业务字段必须创建唯一索引(避免脏数据)
字段过长时指定索引的长度(前缀索引,索引长度越小越好,需计算区分度,【无法排序】)

mysql innodb
5.7- 单个索引字段长度不超过191,联合索引字段长度不超过768
5.7+ 单个索引字段长度不超过767,联合索引字段长度不超过768

字段值设置非NULL,NULL使得索引与索引统计变得复杂。
索引失效问题

!= 、 <> 、 NOT IN、NOT EXISTS 索引失效前缀模糊或者全模糊索引失效 a like '%a' \ a like '%a%'索引字段运算操作后索引失效 a + 1 = 10索引字段加函数后索引失效(非函数索引) date('2022-04-26') = '2022-04-26'字段类型不匹配导致索引失效 int a  a = '0'or 引起索引失效

----------------------------------------------------------------------------------------------------------------------------

4)联合索引,最左匹配原则

由于mysql一次查询只能使用到一个索引,所以再多个查询条件的场景下需要考虑创建联合索引,联合索引需要考虑将查询评率更高的字段放在前面(最左匹配原则)。

联合索引并非在所有使用场景都一定要满足最左匹配原则。在查询条件都是等值匹配时mysql的查询优化器可以优化查询顺序,保证查询时可以使用到该索引【规范最好遵守】。

----------------------------------------------------------------------------------------------------------------------------

5)索引下推

mysql 5.6+ 之后Innodb引擎模式下默认开启了索引下推优化【减少回表的次数】。

举例:联合索引 union_a_b_c(a,b,c)

查询:select * from table_name where a=1 and b like '%b%' and c like '%c%';

无索引下推时:此次查询只能先使用a字段索引查询,再回表查询 b 与 c。

索引下推时:先使用a字段索引查询,然后直接根据索引来判断查询b 与 c。

----------------------------------------------------------------------------------------------------------------------------

6)explain:解析查询计划

id:查询序号
selecttype:查询类型(用于区分普通查询联合查询子查询等复杂查询)
table:查询所针对的表,表名标的别名 derived (from后是子查询) null 直接查询不经过表
type:

system > const > eq_ref > ref > fulltext > ref_or_null > index_merge
> unique_subquery > index_subquery > range > index > ALLall:全表扫描,
index:全索引扫描,
range:索引范围搜索,
ref:使用非唯一索引或者前唯一索的缀扫描,
eq_ref:使用唯一索引扫描,
const/system:单表且最多有一行记录匹配
ref_or_null==>ref:查询条件中包含对null的查询,
index_merge:索引合并优化,
unique_subquery:in 的后面是一个查询主键的子查询,
index_subquery: in 后面是一个非唯一索引的子查询】
一般来说,得保证查询至少达到range级别,最好能达到ref,
type=NULL【mysql不用访问表或者索引,直接获得结果 select 2*5;

possible_key:可能用到的索引
key:最终用到的索引
key_len:使用key的长多
ref:显示哪个字段或常数与key一起被使用
rows:这个数表示mysql要遍历多少数据才能找到,在innodb上是不准确的
extra:

如果是Only index,这意味着信息只用索引树中的信息检索出的,这比扫描整个表要快。
如果是where used,就是使用上了where限制。
如果是impossible where 表示用不着where,一般就是没查出来啥。
此信息显示Using filesort或者Using temporary的话会很吃力,WHERE和ORDER BY的索引
经常无法兼顾,如果按照WHERE来确定索引,那么在ORDER BY时,就必然会引Usingfilesort,
这就要看是先过滤再排序划算,还是先排序再过滤划算【use index 直接查询索引 use where 需要回表查询】

explain extended sql; + show warning;获取经过优化器处理的sql(去除恒等条件 1=1)
explain partitions sql;查看sql所访问的分区

mysql 创建索引规范相关推荐

  1. MySQL 创建索引和索引效率验证

    MySQL 创建索引和索引效率验证 对于一张存储数据的表来说,通常来说数据量会很大. 项目中总会有一些表数据量非常大,并且在使用过程中,需要频繁地到这些表中查询数据. 数据量大的时候,查询速度会明显变 ...

  2. MySQL创建索引失败

    MySQL创建索引失败 报错信息: 原因:将数据库表中某个字段设为索引时,提示当前字段的长度过长,为3072个字节: 经过查询发现: 在mysql5.6中索引列的最大长度为767个字节 而对于utf- ...

  3. navicat下对mysql创建索引导致死锁,数据库崩溃,完美解决方案

    文章目录 写在前面 一.短事务场景下,执行DDL语句场景分析 1.短事务场景下,执行表字段添加操作 2.短事务场景下,执行表字段修改操作 3.短事务场景下,执行表字段删除操作 (1)往里添加一条数据试 ...

  4. SQL CREATE INDEX (mysql 创建索引)语句

    ** SQL CREATE INDEX (mysql 创建索引)语句 ** 1.创建普通索引 SQL CREATE INDEX 语法 在表上创建一个简单的索引.允许使用重复的值: CREATE IND ...

  5. MySQL创建索引(CREATE INDEX)

    索引的建立对于 MySQL 数据库的高效运行是很重要的,索引可以大大提升 MySQL 的检索速度. 基本语法 MySQL 提供了三种创建索引的方法: 1) 使用 CREATE INDEX 语句 可以使 ...

  6. mysql创建索引要加index吗_MySql创建索引,添加索引

    alter table 数据库add index 索引名称(数据库字段名称) PRIMARY KEY(主键索引) ALTER TABLE `table_name` ADD PRIMARY KEY ( ...

  7. MySQL 创建索引

    索引的建立对于 MySQL 数据库的高效运行是很重要的,索引可以大大提升 MySQL 的检索速度. 基本语法 MySQL 提供了三种创建索引的方法: 1 使用 CREATE INDEX 语句 可以使用 ...

  8. mysql 创建索引 key_Mysql中创建索引的INDEX和KEY

    一.问题 被问到,mysql为什么用key创建索引,而不是index.这个被难住了. 二.查一下 关于key和index只有三个页面,primary key,foreign key和create in ...

  9. c mysql创建索引,如何创建mysql索引

    索引是一种特殊的文件(innodb数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针. 注: [1]索引不是万能的! 索引可以加快数据检索操作,但会使数据修改操作变慢.每修 ...

最新文章

  1. 有关Spring 3.0的发布
  2. CornerNet-Lite测试
  3. LSTM:《Understanding LSTM Networks》的翻译并解读
  4. 轴对称 Navier-Stokes 方程组的点态正则性准则 I
  5. 【Linux系统编程】进程内存模型
  6. CSS3 border-image的使用方法
  7. linux实例 批量修改图片文件名
  8. PHP下用Memcache 实现消息队列
  9. 第 69 章 数据库链接
  10. html 页面怎么自动定位到某个标签,JS如何实现在页面上快速定位(锚点跳转问题)...
  11. PHP+Mysql+jQuery找回密码
  12. 百度地图实现定位功能及城市选择
  13. 重心(质量对位置的加权平均)与转动惯量(使物体甩动的难易程度与质量m和到轴的距离r的平方有关)
  14. 00002__Proxyee-down__百度网盘下载加速软件
  15. maya破解版安装python_Maya mayapy.exe 安装 Cython,编译 pyd
  16. 【LabVIEW】基于LabVIEW的俄罗斯方块小游戏
  17. 电源管理IC的分类及智能变化
  18. 计算机音乐谱一壶老酒,一壶老酒简谱(歌词)-陆树铭演唱-沈公宝曲谱
  19. JS 函数的递归算法
  20. 小福利,如何根据爬虫获得的食物卡路里、自身基础热量和运动消耗量计算总的热量差

热门文章

  1. 以云到端创新变革医疗健康服务模式
  2. 2014年华为上机题目
  3. liunx内核配置说明/etc/sysctl.conf
  4. 【详细教程】制作修改安卓系统,轻松当安卓ROM作者
  5. delphi xe mysql_Delphi XE中使用dbExpress连接MySQL数据库疑难问题解决
  6. 有没有能免费下载CSDN资源的方法呢
  7. ActiveReports 大数据分析报告:贸易争端与中国企业数字化转型
  8. qt5 编程入门笔记(持续更新)
  9. 【爬虫作业】使用scrapy爬取游戏发售表,存入mongo数据库
  10. JSON在Java中的使用