mysql索引优化续
(1)索引类型:
Btree索引:抽象的可以理解为“排好序的”快速查找结构
myisam,innodb中默认使用Btree索引hash索引:hash索引计算速度非常的快,但数据是随机放置的,无法对范围进行优化,无法利用前缀索引,排序也无法优化
memory表里默认使用hash索引
(二)单列索引与多列索引
一、单列索引
二、多列索引
怎么才能够让多列索引充分发挥作用?
1.在多列索引上,索引使用匹配需要符合左前缀规则
有如下联合索引:index(a,b,c)
select * from test_table where a=1 and b=2 and c=3; 从左到右都使用到了索引,虽然有大于号,但是也会使用半块索引
select * from test_table where a=1 and c=3 and b=3; mysql很聪明的,虽然查询的条件列不是按照顺序来的,但是mysql会自动识别的所以仍然都可以使用到索引
select * from test_table where a=1 and b=2 and c>3; 从左到右都使用到了索引,虽然有大于号,但是也会使用半块索引
select * from test_table where a=1 and b>2 and c=3; 从左到右都使用到了索引,虽然有大于号,但是也会使用半块索引,依然c列索引也会使用到,所以都使用到了索引
select * from test_table b=2 and c=3; 索引生效是从左到右的如果断掉了后面的索引列就不会生效了,这个没有用到a索引,所以 一个索引都没有使用到
select * from test_table b=2; 同上
select * from test_table c=3; 同上
分组统计建议要先按照分组的字段进行排序然后再统计
我们想知道某条sql语句是不是按照我们希望的方式使用了索引我们可以使用explain来查看sql语句的执行计划:
explain用法说明:
只需要在sql语句前面加上explain即可
mysql> explain select * from t where c1='a' and c5='e' order by c2,c3;
+----+-------------+-------+------+---------------+------+---------+-------+------+--------------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-------+------+---------------+------+---------+-------+------+--------------------------+
| 1 | SIMPLE | t | ref | c1 | c1 | 3 | const | 6 | Using where; Using index |
+----+-------------+-------+------+---------------+------+---------+-------+------+--------------------------+
table:表示使用的数据表
type:连接类型有多个值,不同的值体现了sql语句不同的优化级别
keys:mysql使用的索引
key_len:mysql使用的索引长度
rows:mysql执行查询的行数,数值越大越不好说明没有用好索引
extra:mysql解决查询的详细详细有几个参数需要解释下
using filesort:说明使用执行该sql语句先使用了数据排序
using index:说明使用了索引
using temporary:说明mysql创建了临时表来容纳结果
(三)show profiles的使用
一般情况情况是这样的我们考虑需要建立给表建立索引是由于查询缓慢,这个时候我们可以通过开启show profiles来了解我们优化的进展,和方案的可行性。
show profiles:默认一般都是关闭的,但是会话级别可以开启这个功能,开启后可以让mysql收集在执行sql语句时的所有相关信息,通过这个可以比较明确的了解优化的成果。
1.查看show profile是否开启
mysql> show variables like "%pro%";
+---------------------------+-------+
| Variable_name | Value |
+---------------------------+-------+
| have_profiling | YES |
| profiling | OFF |
| profiling_history_size | 15 |
| protocol_version | 10 |
| proxy_user | |
| slave_compressed_protocol | OFF |
| stored_program_cache | 256 |
+---------------------------+-------+
2.如果profiling关闭了则开启选项
mysql> set profiling=1;
3.查看sql语句运行的信息
在开启profile后系统中执行的sql语句都将被记录
mysql> show profiles;
+----------+-------------+--------------------------------------------------------------------------------------------------------+
| Query_ID | Duration | Query |
+----------+-------------+--------------------------------------------------------------------------------------------------------+
| 1 | 0.00031950 | show variables like "%pro%" |
| 2 | 0.00020125 | show tables |
| 3 | 0.40749175 | select count(*) from b2b_my_test_value |
| 4 | 0.00008600 | show processlist |
| 5 | 0.40956300 | select count(*) from b2b_my_test_value |
| 6 | 0.00007225 | show profile for query |
| 7 | 0.00004150 | show profile for query |
| 8 | 23.30362350 | select avg(`my_age`),`my_aihao` from b2b_my_test_value group by `my_aihao` |
| 9 | 0.00018900 | show index from b2b_my_test_value |
| 10 | 0.00015050 | explain select avg(`my_age`),`my_aihao` from b2b_my_test_value group by `my_aihao` |
| 11 | 0.00014875 | explain select avg(`my_age`),`my_aihao` from b2b_my_test_value group by `my_aihao` |
| 12 | 0.00016725 | explain select avg(`my_age`),`my_aihao` from b2b_my_test_value group by `my_aihao` order by `my_aihao` |
| 13 | 0.00018725 | explain select avg(`my_age`),`my_aihao` from b2b_my_test_value group by `my_aihao` |
| 14 | 0.00020875 | show index from b2b_my_test_value |
| 15 | 0.00008125 | explain select avg(`my_age`),`my_aihao` from b2b_my_test_value where group by `my_aihao` |
+----------+-------------+--------------------------------------------------------------------------------------------------------+
15 rows in set, 1 warning (0.00 sec)
这样我们就可以很方便的了解sql执行的时间了
mysql索引优化续的更多相关文章
- mysql索引优化
mysql 索引优化 >mysql一次查询只能使用一个索引.如果要对多个字段使用索引,建立复合索引. >越小的数据类型通常更好:越小的数据类型通常在磁盘.内存和CPU缓存中都需要更少的空间 ...
- Mysql 索引优化分析
MySQL索引优化分析 为什么你写的sql查询慢?为什么你建的索引常失效?通过本章内容,你将学会MySQL性能下降的原因,索引的简介,索引创建的原则,explain命令的使用,以及explain输出字 ...
- 知识点:Mysql 索引优化实战(3)
知识点:Mysql 索引原理完全手册(1) 知识点:Mysql 索引原理完全手册(2) 知识点:Mysql 索引优化实战(3) 知识点:Mysql 数据库索引优化实战(4) 索引原理知识回顾 索引的性 ...
- MySQL索引优化步骤总结
在项目使用mysql过程中,随着系统的运行,发现一些慢查询,在这里总结一下mysql索引优化步骤 1.开发过程优化 开发过程中对业务表中查询sql分析sql执行计划(尤其是业务流水表),主要是查看sq ...
- MySQL索引优化看这篇文章就够了!
阅读本文大概需要 5 分钟. 来源:cnblogs.com/songwenjie/p/9410009.html 本文主要讨论MySQL索引的部分知识.将会从MySQL索引基础.索引优化实战和数据库索引 ...
- mysql索引优化比普通查询速度快多少
mysql索引优化比普通查询速度快多少 一.总结 一句话总结:普通查询全表查询,速度较慢,索引优化的话拿空间换时间,一针见血,所以速度要快很多. 索引优化快很多 空间换时间 1.软件层面优化数据库查询 ...
- mySql索引优化分析
MySQL索引优化分析 为什么你写的sql查询慢?为什么你建的索引常失效?通过本章内容,你将学会MySQL性能下降的原因,索引的简介,索引创建的原则,explain命令的使用,以及explain输出字 ...
- 【ZZ】MySQL 索引优化全攻略 | 菜鸟教程
MySQL 索引优化全攻略 http://www.runoob.com/w3cnote/mysql-index.html
- mysql数据库优化课程---17、mysql索引优化
mysql数据库优化课程---17.mysql索引优化 一.总结 一句话总结:一些字段可能会使索引失效,比如like,or等 1.check表监测的使用场景是什么? 视图 视图建立在两个表上, 删除了 ...
随机推荐
- 20145314郑凯杰《网络对抗技术》实验5 MSF基础应用
20145314郑凯杰<网络对抗技术>实验5 MSF基础应用 1.0 MS08_067安全漏洞 1.1 实验目标 了解掌握metasploit平台的一些基本操作,能学会利用已知信息完成简单 ...
- POJ 3159 Candies(差分约束+最短路)题解
题意:给a b c要求,b拿的比a拿的多但是不超过c,问你所有人最多差多少 思路:在最短路专题应该能看出来是差分约束,条件是b - a <= c,也就是满足b <= a + c,和spfa ...
- MyBatis基本工作原理
Application是程序员开发的Java代码,蓝色为MyBatis框架. API是MyBatis提供的增删改查等功能接口. 老式SQL写法我们在Dao中写SQL: SELECT * FROM us ...
- CCNA学习指南 -开放最短路径优先OSPF(单区域)
在上个世纪九十年代撰写的<TCP/IP协议详解 卷一:协议>的动态选路中,内容大部分还是介绍 RIP路由选择信息协议,在互联网络如此发达的今天,RIP因为它的局限性逐步被OSPF取代. 在 ...
- 与R纠缠的两件事——rownames和子集--转载
与R语言纠缠了一个星期,从快速上手的暗暗得意,到之后某些细节的纠结烦躁,过山车式体验中,我逐渐才认识了真实的R语言. 期间遇到两个很烦恼的问题,一个是让人烦躁抓狂,另一个是无意发现的重大错误. 1. ...
- Android 旋转、平移、缩放和透明度渐变的补间动画
补间动画就是通过对场景里的对象不断进行图像变化来产生动画效果.在实现补间动画时,只需要定义开始和结束的“关键帧”,其他过渡帧由系统自动计算并补齐.在Android中,提供了以下4种补间动画. **1. ...
- PHP--------微信网页开发实现微信扫码功能
今天说说微商城项目中用到的扫一扫这个功能,分享一下,希望对各位有所帮助. 前提:要有公众号,和通过微信认证,绑定域名,得到相应信息,appid,appsecret等. 微信开发文档:https://m ...
- Android 之低版本高版本实现沉浸式状态栏
沉浸式状态栏确切的说应该叫做透明状态栏.一般情况下,状态栏的底色都为黑色,而沉浸式状态栏则是把状态栏设置为透明或者半透明. 沉浸式状态栏是从android Kitkat(Android 4.4)开始出 ...
- iptable filter nat MASQUERADE snat dat
在这里,系统会根据IP数据包中的destination ip address中的IP地址对数据包进行分发.如果destination ip adress是本机地址,数据将会被转交给INPUT链.如果不 ...
- 003——数组(三)count()reset()end()prev()next()current()
<?php /** * count 统计数组中元素的个数 */ /*$arr=array('blog.com','博客论坛',array('php课程','css课程')); echo coun ...