mysql -- 索引补充
.unique索引补充:联合唯一 unique(name,email)是name和email这两列联合起来唯一,不再试某个字段唯一 .主键索引,类似唯一索引,也是允许联合多个字段作为主键,例如:primary(nid,name) .组合索引,多列共同组成索引
注意:例如index(name,email)---->最左前缀
select* from info where name='xxx' and email ='xxx' 是走索引的
select* from info where name='xxx' 是走索引的
select* from info where email ='xxx' 是不走索引的
索引分类:
普通索引:仅仅起到加速查询作用
唯一索引:加速查询+列值唯一(可以为null)
主键索引:加速查询+列值唯一+表中只有一个(不可以为null)
组合索引:多列值组合成一个所有,专门用于组合搜索,效率会大于索引合并
全文索引:对文本内容进行索引,进行搜索,一般不会使用,会使用插件等加速全文索引的查找效率
查看表中索引
show index from 表名
单独创建索引
create index 名字 on 表(列)
获取索引等级type:const(效率几乎是最高的),all(全表扫描,效率最低),
等级划分:
all:去数据表全表扫描
index:去索引表扫描
range:对索引列进行范围查找,除了!=和>符号以外的范围操作
index_merge:合并索引,使用多个单列索引搜索
ref:根据索引查找一个或多个
eq_ref:唯一索引操作,只能拿到一个数据
const:常量,值匹配到一行
system:几乎用不到
explain select * from info where name = 'xxx' ---type:all/const/..
注意:不是建立了索引,就会加快查找速率,若是建立索引,但是使用错误的方式去操作,会导致索引变慢,变成全表扫描(默认)。
例如:name没有建立索引
select * from info where name='aaa';//第一条,但是其依旧会全表扫描
limit使用:在没有建立索引时使用会加快查找速率
select * from info where name='aaa' limit ;//第一条,但是找到第一条后就返回,但是还是最后一条,搜索还是非常慢的
但是正确的索引建立和使用会使查询效率变得非常快
重点(正确使用索引)
1.like '%xx'
select * from info where name like '%三';
上面这种情况即使建立例索引,也不会去走这个索引
select * from info where name like '张%';
这种情况会走索引
2.使用函数
对索引列加函数也不能走索引,因为会对每一个索引列的值都取出用函数处理,导致索引不能使用
select * from info where reverse(name) = '四李';//name是建立了索引的
修改,是函数添加到后面的数据上,只会执行一次函数
select * from info where name = reverse('四李');//name是建立了索引的
3.or作为条件
当两边中的列,若是一方没有建立索引,则不能走索引,必须两方都建立索引才行
4.类型不一致
select * from info where name='张三'; //name是建立的索引,类型varchar,一致可以走索引
但是
select * from info where name=; //name是建立的索引,类型varchar,数据为int类型,不一致不可以走索引
5.比较符号
大于和不等于不会走索引,会去全表扫描
6.order by
当根据索引排序的时候,选择的映射如果不是索引,则不会走索引
select name from info order by age desc //age是所有,映射name也是索引
当映射不是索引不会走索引
select score from info order by age desc //score不会是索引不会走索引
特别的,对于主键还是会走索引的
7.组合索引最左前缀
补充:
覆盖索引
在创建索引时,会将索引和数据分为两个文件存储
例如name创建索引了
select name from info where name='ls';
索引合并
单独的索引,联合使用
select * from info where name='ls' and gender=''; //index(name) index(gender)
组合索引
效率高于索引合并
组合索引
select * from info where name='ls' and gender=''; //index(name,gender)
注意事项
1.尽量少用select*,尽量少取多余数据出来
2.count(1)或者count(列)代替count(*)
3.创建表的时候,尽量使用char,少使用varchar,char更易检索
4.固定字节int,char,tinyint等往前放,类似于结构体,固定长度的步长确定,易于跳转,不定长度需要计算步长,动态操作
5.组合索引代替多个单列索引(当经常使用多个条件同时查询时)
6.尽量使用短索引:像一堆字符串,若是前面几位已经不同,则不需要将所有的字符串都建立索引,导致索引文件过大,降低效率
7.使用连接join代替子查询
8.连表示注意类型一致
9.所有散列值不适合建立索引,例如性别
mysql -- 索引补充的更多相关文章
- mysql索引补充
索引补充 1.索引 索引是表的目录,在查找内容之前可以先在目录中查找索引位置,以此快速定位查询数据.对于索引,会保存在额外的文件中. 2.索引种类 普通索引:仅加速查询 唯一索引:加速查询 + 列 ...
- mysql索引与补充
一, 什么是索引 为什么要有索引? 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,在生产环境中,我们遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,因此 ...
- mysql数据库补充知识7 索引原理与慢查询优化
一 介绍 为何要有索引? 一般的应用系统,读写比例在10:1左右,而且插入操作和一般的更新操作很少出现性能问题,在生产环境中,我们遇到最多的,也是最容易出问题的,还是一些复杂的查询操作,因此对查询语句 ...
- 【转】MySQL索引背后的数据结构及算法原理
摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同,因此MySQL数据库支持多种索引类型,如BT ...
- [转]MySQL索引背后的数据结构及算法原理
摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同,因此MySQL数据库支持多种索引类型,如BT ...
- MySQL索引背后的数据结构及算法原理
摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同,因此MySQL数据库支持多种索引类型,如BT ...
- [纯干货] MySQL索引背后的数据结构及算法原理
摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同,因此MySQL数据库支持多种索引类型,如BT ...
- MySQL 索引背后的数据结构及算法原理
本文转载自http://blog.jobbole.com/24006/ 摘要本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引 ...
- 浅谈MySQL索引背后的数据结构及算法(转载)
转自:http://blogread.cn/it/article/4088?f=wb1 摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储 ...
随机推荐
- 对TCP重传的进一步认识
http://blog.sina.com.cn/s/blog_4d276ac901011ee7.html ——TCM项目所得 一.看图说话 1.基于套接字的TCP服务器/客户端程序流程 2.TCP三次 ...
- shell脚本--显示文本内容
shell脚本显示文本内容及相关的常用命令有cat.more.less.head.tail.nl 首先是cat,cat最常用的就是一次性显示文件的所有内容,如果一个文件的内容很多的话,那么就不是很方便 ...
- BZOJ4196[Noi2015]软件包管理器——树链剖分+线段树
题目描述 Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖(即下载安装这个 ...
- SQL语言分类DQL,DML,DDL,DCL,DTL
SQL语言共分为五大类: 数据查询语言DQL 数据操纵语言DML 数据定义语言DDL 数据控制语言DCL 数据事物语言DTL DQL 数据查询语言DQL基本结构是由SELECT子句,FROM子句,WH ...
- Android 访问 Webapi 更新UI
首先,写一个访问webapi的工具类 import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import or ...
- bzoj 2202 [HNOI2010] Bounce 弹飞绵羊(分块)
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2002 思路:和之前那道树分块的题很像,只不过那道是在树上,这道简单些在序列上 还是维护两个数 ...
- HihoCoder - 1498 Diligent Robots
There are N jobs to be finished. It takes a robot 1 hour to finish one job. At the beginning you hav ...
- day29 上周复习
上周内容回顾 初始面向对象 class 类名(父类1,父类2): 静态属性 = "" # 静态属性,类方法 def __init__(self): # 初始化方法 def func ...
- 【POI每日题解 #9】SKA-Piggy Banks
题目链接 题意: 有一棵环套树 求最少从多少个节点出发能沿边走过整棵树 环套树 并查集求联通块 有几块就砸几个 太简单不发代码了 不过某大佬的环套树找环dfs让我研究了好久… 贴一下以Orz #inc ...
- BZOJ 4004 [JLOI2015]装备购买 | 线性基
题目链接 Luogu P3265 题解 非常正常的线性基! 但是我不会线性基-- (吐槽:#define double long double 才过--) #include <cstdio> ...