网易DBA私享会分享会笔记2
mysql索引与查询优化
什么是索引?索引其实是一个目录。通过各种数据结构实现,是(值=>行位置)的映射
索引的作用:
1.提高访问速度
2.实现主键、唯一键逻辑
索引使用场景
数据量特别大的时候,进行全表扫描(无索引),就会很慢,有索引的话就会减少I/O,减少时间(等值查询)
索引的类型:指的是实现索引的数据结构
Btree索引,实际上是B+tree,Mysql甚至绝大部分是RDBMS是最主要的架构
Hash索引:主要是用于Innodb,一些内存索引结构,一家MEMORY存储引擎
RTree索引(淘汰):用于地理位置检索,MyIsam引擎专有
fulltext索引 主要用于MyIsam引擎
Bitmap索引(用的比较少) 原生的mysql不支持位图索引
innodb聚簇索引与二级索引
这个表本身也建成一个索引,按主键依次排序、
二级索引:用户建的索引
先找二级索引-->找到主键--->找到相应内容
索引的代价
插入、修改、删除操作,每一个索引都会变成一个内部事务,索引越长,事务越长(平衡二叉树)、
索引的优势
减少查询I/O 、等值查询/范围查询、有序特性(order by、group by、distinct、max、min)
索引的常用用法
1.根据where查询条件建立索引
select a.b from table_a where c = ?; 在c上建立索引
2.使用联合索引,而不是多个单列索引
select * from tab_a where a=? And b=? //建立一个联合索引 idx_a_b(a,b)
3.联合索引中索引字段的顺序,根据区分度排,区分度大的排前面 //区分度指的是 取值范围更广。比如name,而不是gender
idx_smp(name,gender)
索引的常见用法
1.联合索引能为前缀单列、复列查询提供查询
idx_smp(a,b,c)
_where a=? or where a =? and b=?
查询条件必须从左到右都包含,才能走abc
同样的,合理创建联合索引,避免冗余
查看是否使用索引:explain命令
explain select userid from PRIS_trade where
explain 是确定一个查询如何走索引的最简单有效方法
关注项目:
type:查询access方式
key:本次查询最终使用哪个索引,null为未使用索引
key_len:选择索引使用的前缀长度或者整个长度
rows:可以理解为查询逻辑需要扫描过的记录行数
extra:额外信息,主要指fetch data具体方式
(执行计划)
小结:
对不确定的执行语句的关键语句上线前务必使用explain
Type为null的要格外注意,避免全表扫描
key_len只能用很少一部分前缀的要注意索引字段顺序
Extra只看到Using filesort,Using tempotary都要尽量优化
强制使用索引hint
select * from table1 force index(field1)
select * from table1 ingore index(field1)
网易DBA私享会分享会笔记2的更多相关文章
- 网易DBA私享会分享会笔记1
1.mysql生态+DBA职业发展世界范围流行的开源关系型的数据库关系型数据库:mysql,oracle,sql server,access,postgresql,sqlite,sybase,info ...
- 微软CEO私享会——广东天使会专场圆满落幕
http://www.cnblogs.com/sennly/p/4140976.html 10月17日,微软中国联合广东天使会首期“微软CEO 私享会”在中国微软广东分公司广州太古汇办公室举 ...
- 鹿定制|Lu Couture|鹿定制·高级西装礼服私享定制品牌|芙蓉中路明城国际1425
鹿定制|Lu Couture|鹿定制·高级西装礼服私享定制品牌|芙蓉中路明城国际1425 联系我们
- 子弹短信光鲜的背后:网易云信首席架构师分享亿级IM平台的技术实践
本文原文内容来自InfoQ的技术分享,本次有修订.勘误和加工,感谢原作者的分享. 1.前言 自从2018年8月20日子弹短信在锤子发布会露面之后(详见<老罗最新发布了“子弹短信”这款IM,主打熟 ...
- 轻量级企业私有云 JimV 分享
当前云市场分析 云分两种,公有云.私有云.目前市面上的云产品,对于中小规模的企业来讲,痛点有如下几点: 私有云: 1.VMware ESXi 类: a) 授权费用昂贵: b) 创建虚拟机费时费力: 2 ...
- HBase分享会议笔记
今天参加了一个关于HBase的分享,有一些内容是之前的知识的补充. 之前关于Hadoop家族,包括HBase的内容,可以参考:http://www.cnblogs.com/charlesblc/p/6 ...
- jvm虚拟机分享课笔记
深入理解jvm虚拟机分享 1. jvm执行流程 java-编译-.class—类加载器(随时随地加载)--[进入java虚拟机] 执行引擎—本地方法接口---本地方法库 运行时数据区 2. 运行时数据 ...
- 2014MadCon厦门分享会-笔记(下)
32 <如何与百度互动,不知道这些就不要做SEO了>百度站长平台资深产品运营师 曹丽丽(飞鸟) 33 注意百度站长平台的提醒.如果你不留电话,不留其他联系方式,出问题了,百度怎么提醒你呢? ...
- MySQL数据库性能优化(享学课堂听课笔记)
1.场景: 2张表A表 200W条数据,关联表B表3W条数据,AB有主外键关系. 案例1. 35S 使用关联子查询,查询时间35S 案例2. 19S 使用连表查询 (Left join ,Inner ...
随机推荐
- 数据结构(Splay平衡树):HDU 1890 Robotic Sort
Robotic Sort Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ...
- 加密解密,CryptoStream()的使用
一:上图 二:代码 主界面代码 using System; using System.Collections.Generic; using System.ComponentModel; using S ...
- 数据结构——POJ 1686 Lazy Math Instructor 栈的应用
Description A math instructor is too lazy to grade a question in the exam papers in which students a ...
- bzoj 3158 千钧一发(最小割)
3158: 千钧一发 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 767 Solved: 290[Submit][Status][Discuss] ...
- 最小生成树——[HAOI2006]聪明的猴子
题目:[HAOI2006]聪明的猴子 描述: [题目描述] 在一个热带雨林中生存着一群猴子,它们以树上的果子为生.昨天下了一场大雨,现在雨过天晴,但整个雨林的地表还是被大水淹没着, 猴子不会游泳,但跳 ...
- 从cpu加电到加载OS内核的详细过程(清华大学ucore-lab1总结一)
结合最近学习清华的OS课,先用“人话”来高度抽象的描述一下我自己的理解.CPU在系统加电也就是我们按下电源开关后,开始初始化他的寄存器,主要是cs和eip(本文基于x86架构),然后在ROM中找到一个 ...
- poj1017
一个工厂制造的产品形状都是长方体,它们的高度都是h,长和宽都相等,一共有六个型号,他们的长宽分别为1*1, 2*2, 3*3, 4*4, 5*5, 6*6.这些产品通常使用一个 6*6*h 的长方体包 ...
- oGitHub 注册
GitHub 注册 要想使用 GitHub 第一步当然是注册 GitHub 账号: 1.首先打开 https://github.com/pricing 进行注册. 2.在打开的页面中点击「Sign u ...
- 实战:sqlserver 数据实时同步到mysql
1.安装安装mysqlconnector 2.配置mysqlconnector ODBC数据管理器->系统DSN->加入->mysql ODBC 5.3 ANSI driver-&g ...
- 黑马程序猿_try-catch-finally
------- android培训.java培训.期待与您交流! ---------- try-catch-finally中怎样定义语句呢? 1.try块中主要定义可能出现的异常处理语句 2.catc ...