网易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 ...
随机推荐
- OSGI在Eclipse中执行-console出错的问题
在Eclipse中安装osgi插件后,执行出现异常:
- 搭建ftp环境
首先明确,ftp站点设置在服务器上,而在客户端上来使用ftp工具来进行上传文件 具体环境搭建如下两个链接,一个server2003,一个是win7 server2003:http://jingyan. ...
- vijosP1194 Domino
vijosP1194 Domino 链接:https://vijos.org/p/1194 [思路] 矩阵相乘. 参考Matrix67的文章: [代码] #include<cstdio> ...
- python urllib2详解及实例
urllib2是Python的一个获取URLs(Uniform Resource Locators)的组件.他以urlopen函数的形式提供了一个非常简单的接口, 这是具有利用不同协议获取URLs的能 ...
- Hard 随机选择subset @CareerCup
算法同上题 package Hard; import CtCILibrary.AssortedMethods; /** * Write a method to randomly generate a ...
- 项目经历——EasyUI的检索和更新操作
什么事都耐不住“磨”?! 比如一个让人很头疼的问题,对于项目中所用到的EasyUI框架就是一个很明显的感受.项目使用的EasyUI框架,自身封装好的样式使得开发者不用考虑具体的div和css样式了,但 ...
- Android Bitmap开发之旅--基本操作
1 Bitmap加载方式 在介绍Bitmap--OOM 异常时,首先介绍一下Bitmap有哪几种加载方式.通常Bitmap的加载方式有Resource资源加载.本地(SDcard)加载.网络加载等加载 ...
- searchbar的使用介绍
searchBar的使用介绍 首先如何创建一个SearchBar实例: self.searchBar = [[UISearchBar alloc] initWithFrame: CGRectMake( ...
- Gson解析json数据(转)
一. www.json.org这是JSON的官方网站. 首先,我,我们需要在code.google.com/p/google-gson/downloads/list下载JSON的jar包,解析后把gs ...
- NSPredicate查询日期的问题
查询日期的时候日期可以根据参数传进去,但不能在字符串中传参后在作为查询条件 简单比较以下两段代码 NSDate* date1=[NSDate date]; NSDate* date2=date1; r ...