MySQL索引的学习
MySQL索引的学习
关于使用mysql索引的好处,合理的设计并使用mysql索引能够有效地提高查询效率。对于没有索引的表,单表查询可能几十万数据就是平静,在大型网站单日可能会产生几十万甚至几百万的数据,没有索引是非常缓慢的。
测试未添加任何索引,查询需要的时间非常恐怖的,如果加上联合查询和其他一些约束条件,数据库会疯狂的消耗内存,并且会影响前端程序的执行。
索引的概念
索引是特殊的一种文件(InnoDB数据表上的索引是表空间的一个组成部分,MyISAM表上的索引是和表空间分开的),索引主要包含对数据表中所有记录的引用指针。相当于一本书的目录,加快查找的速度。一般数据库默认为主键生成索引。
索引分为聚簇索引和非聚簇索引两种,聚簇索引是按照数据存放的物理位置为顺序的。而非聚簇索引就不一样;聚簇索引能够提高多行检索的速度,而非聚簇索引对于多行检索很快。
普通索引
基本的索引,没有任何限制。MyIASM中默认的是BTREE类型的索引。
唯一索引
与普通的索引类似,不同的是:索引列的值必须唯一,但允许有空值(与主键不同)。如果是组合索引,则列值的组合必须唯一,创建方法和普通索引的创建索引方式类似。
全文索引
MySQL从3.23.23版开始支持全文索引和全文检索,FULLTEXT索引仅能使用与MyISAM表。他们可以从HCAR、VARCHAR或者TEXT列中作为CREATE TEABLE语句的一部分被创建,或者之后使用ALTER TABLE或CREATE INDEX被添加。先输入FULLTEXT数据之后在创建索引速度比创建索引之后再输入速度更快。对于大容量的数据表,生成全文索引是一个特别消耗时间、消耗空间的做法。
单列索引、多列索引
多个单列索引与单个多列索引的查询效果是不同的,因为执行查询时,MySQL只能使用一个索引,会从多个索引中选择一个限制最为严格的索引。
组合索引(最左前缀)
平时经常使用的SQL查询语句存在比较多个限制条件,为了更快的提高效率,就需要考虑建立组合索引。针对title和time建立一个组合索引:ALTER TABLE article ADD INDEX index_titme_time (title(50),time(10))。建立这样的组合索引,其实是相当于分别建立了下面两组组合索引:
- title,time
- title
为什么没有time这样的组合索引呢?这是因为MySQL组合索引“最左前缀”的结果。简单的理解就是只从最左面的开始组合。并不是只要包含这两列的查询都会用到该组合索引
MySQL索引的优化
过多的使用将会造成滥用。索引大大提高了查询速度,同时却会降低更新表的速度,如对表进行INSERT、UPDATE和DELETE。因为更新表的时候,MySql不仅要保存数据,同时还需要保存一下索引文件。建立索引会占用磁盘空间的索引文件。一般情况下问题不严重,如果在一个大表创建了多种组合索引,索引文件就会膨胀。
使用聚集索引与非聚集索引情况
| 描述 | 是否使用聚集索引 | 是否使用非聚集索引 |
|---|---|---|
| 列经常被分组使用 | 是 | 是 |
| 返回某范围的数据 | 是 | 否 |
| 一个或极少的不同值 | 否 | 否 |
| 小数目的不同值 | 是 | 否 |
| 大数目的不同值 | 否 | 是 |
| 频繁的数目更新 | 否 | 是 |
| 外键列 | 是 | 是 |
| 主键列 | 是 | 是 |
| 频繁修改索引列 | 否 | 是 |
索引不包含NULL值
只要列中包含有NULL值都将不会被包含在索引中,复合索引中只要有一列含有NULL值,那么这一列对于此复合索引就是无效的。所以我们在数据库设计时不要让字段的默认值为NULL。
使用短索引
对串列进行索引,如果可能应该指定一个前缀长度。
索引列排序
MySQL查询只使用一个索引,因此如果where子句中已经使用了索引的话,那么order by中的列是不会使用索引的。因此数据库默认排序可以符合要求的情况下不要使用排序操作;尽量不要包含多个列的排序,如果需要最好给这些列创建复合索引。
like语句操作
一般情况下不鼓励使用like操作,如果非使用不可,如何使用也是一个问题。like “%aaa%” 不会使用索引而like “aaa%”可以使用索引。
不要在列上进行运算
运算导致索引失效而进行全表扫描。
注
MySQL只对一下操作符才使用索引:<,<=,=,>,>=,between,in,以及某些时候的like(不以通配符%或_开头的情形)。
理论上每张表里面最多可创建16个索引,不过除非是数据量真的很多,否则过多的使用索引也不是那么好玩的
索引使用的限制
- MyISAM存储引擎索引长度的综合不能够超过1000字节;
- BLOB和TEXT类型的列只能创建前缀索引;
- MySQL目前不支持函数索引;
- 使用不等于(!=或者>、<)的时候,MySQL无法使用索引;
- 过滤字段使用了函数运算后,MySql无法使用索引;
- Join语句中Join条件字段类型不一致的时候,MySQL无法使用索引;
- 使用LIKE操作的时候,如果条件以通配符开始(“%key”)时,MySQL无法使用索引;
使用非等值查询的时候,MySQL无法使用Hash索引。
MySQL索引的学习的更多相关文章
- MySQL索引知识学习笔记
目录 一.索引的概念 二.索引分类 三.索引用法 四 .索引架构简介 五.索引适用的情况 六.索引不适用的情况 继我的上篇博客:Oracle索引知识学习笔记,再记录一篇MySQL的索引知识学习笔记,本 ...
- Mysql 索引案例学习
理解索引最好的办法是结合示例,所以这里准备了一个索引的案例. 假设要设计一个在线约会网站,用户信息表有很多列,包裹国家,地区,城市,性别,眼睛颜色,等等.完整必须支持上面这些特征的各种组合来搜索用户, ...
- mysql实战优化之四:mysql索引优化
0. 使用SQL提示 用户可以使用use index.ignore index.force index等SQL提示来进行选择SQL的执行计划. 1.支持多种过滤条件 2.避免多个范围条件 应尽量避免在 ...
- SQL学习笔记之MySQL索引知识点
0x00 概述 之前写过一篇Mysql B+树学习,简单的介绍了B+数以及MySql使用B+树的原因, 有了这些基础知识点,对MySql索引的类型以及索引使用的一些技巧,就比较容易理解了. 0x01 ...
- 重新学习MySQL数据库5:根据MySQL索引原理进行分析与优化
重新学习MySQL数据库5:根据MySQL索引原理进行分析与优化 一:Mysql原理与慢查询 MySQL凭借着出色的性能.低廉的成本.丰富的资源,已经成为绝大多数互联网公司的首选关系型数据库.虽然性能 ...
- 重新学习MySQL数据库4:Mysql索引实现原理
重新学习Mysql数据库4:Mysql索引实现原理 MySQL索引类型 (https://www.cnblogs.com/luyucheng/p/6289714.html) 一.简介 MySQL目前主 ...
- 10 | MySQL为什么有时候会选错索引? 学习记录
<MySQL实战45讲>10 | MySQL为什么有时候会选错索引? 学习记录http://naotu.baidu.com/file/e7c521276650e80fe24584bc9a6 ...
- 重新学习Mysql数据库4:Mysql索引实现原理和相关数据结构算法
本文转自互联网 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial ...
- SQL学习笔记五之MySQL索引原理与慢查询优化
阅读目录 一 介绍 二 索引的原理 三 索引的数据结构 四 聚集索引与辅助索引 五 MySQL索引管理 六 测试索引 七 正确使用索引 八 联合索引与覆盖索引 九 查询优化神器-explain 十 慢 ...
随机推荐
- Android笔记之启动界面的设置
默认情况下,启动界面是白屏 我们自定义一个启动界面如下,3秒钟后进入主界面并结束启动页 SplashActivity.java package com.bu_ish.myapp; import and ...
- php不使用递归实现无限极分类
无限极分类常用的是递归,但是比较不好理解,其实可以用数据库path,pid两个字段的设计来实现无限分类的功能 1.数据库设计 通过上图可以看出pid就是该栏目的父id,而path = 父path+pi ...
- hihocoder #1062 : 最近公共祖先·一(小数据量 map+set模拟+标记检查 *【模板】思路 )
#1062 : 最近公共祖先·一 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho最近发现了一个神奇的网站!虽然还不够像58同城那样神奇,但这个网站仍然让小Ho乐在 ...
- 使用Dubbo实现RPC调用
启动Dubbo服务有2个方式,1是通过xml配置,2是通过注解来实现,这点和Spring相似. 采用XML配置如下: <?xml version="1.0" encoding ...
- 【C】论‘\r’和'\n'的纯粹性
- Asterisk func group
Synopsis Gets, sets or clears the channel group. Each channel can only be member of exactly one grou ...
- 【CQ18高一暑假前挑战赛4】标程
[二分或者STL] 二分: #include<bits/stdc++.h> using namespace std; ; int a[maxn]; int main() { ,pos; s ...
- shell---rpm
[root@master src]# rpm -qpl epel-release-latest-6.noarch.rpm ##查询该rpm包安装了什么warning: epel-rel ...
- codevs 1046 旅行家的预算
传送门 1046 旅行家的预算 1999年NOIP全国联赛普及组NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold题解 题目描述 Des ...
- mtk lk阶段的lcm流程
一.lk进入kmain() 1. vendor/mediatek/proprietary/bootable/bootloader/lk/arch/arm/srt0.S bl kmain 二.初始化lk ...