Mysql性能优化笔记
一,索引
1.Innodb索引使用的是B+树
2.尽量简化where条件,比如不要出现 where id + 3 = 5,这无法使用索引
3.索引很大时,可以冗余一列来模拟哈希索引
4.小的表不需要使用索引,很大的表需要用分块技术,也不用索引
5.索引的选择性=不重复的数量/总的数量
选择性越高,效率越高,unique索引选择性为1,效率最好
对于blob,text,很长的varchar类型的列,必须使用前缀索引。
诀窍在于,要选择足够长的前缀以保证较高的选择性,同时又不能太长
创建前缀索引:(city列里长度为7的前缀索引)
alter table sakila.city_demo ADD KEY(city(7))
前缀索引的缺点,无法做ORDER BY和GROUP BY
后缀索引:mysql不支持反向索引,但可以把字符串反转后存储,并基于此建立索引,可以通过触发器来维护索引
6、多列索引
对多个列做相交操作(and)时,需要的时一个多列索引而不是多个单独的单列索引
如果在explain中看到有索引合并,应该好好检查一下查询和表单结构,
可以通过参数optimizer_switch来关闭索引合并
7.覆盖索引
如果一个索引包含所有需要查询的字段的值,我们就称之为覆盖索引
由于myISAM在内存中只存索引,所以用覆盖索引有严重的性能问题
由于InnoDB的聚簇索引,覆盖索引对InnoDB特别有用
另外,只能用B-tree索引做全文索引
当使用覆盖索引时,EXPLAIN 中的Extra中显示Using index
查询优化
一般的优化方法有两个
1.确认应用程序是否在检索大量超过需要的数据,这通常意味着访问了太多的行
但有时候也可能是访问了太多的列
2.确认MySQL服务器层是否在分析大量超过需要的数据行
解决方法,加limit,
如果数据库资源紧张,可以考虑用mybatis代替hibernate
取出全部列,会让优化器无法完成覆盖索引扫描这类优化,比如hibernate
不过获取所有列的查询缓存,比多个独立的只获取部分列的查询缓存更有好处
每次看到select * 请去怀疑一下是否真的需要全部取出
重复查询相同的数据:请把这个数据缓存起来,比如放到session中
最简单的衡量查询开销的三个指标:
响应时间,
扫描的行数
返回的行数
这三个指标都会记录到mysql的慢日志中,所以检查慢日志
如果发现查询需要扫描大量的数据行,但返回少量的行,那么可以尝试下面的技巧去优化它
1,使用索引覆盖扫描,把所有需要用的列都放到索引中
2.改变表结构,例如使用单独的汇总表
3.重写这个查询,各种优化
有时可以考虑将一个复杂查询分为多个小查询,如果能减少工作量的话
比如删除旧的数据,每次删一点,可以避免一次锁住很多数据
分解关联查询的好处
1、缓存效率更高
2、用返回的数据的id来进行顺序查询比用join进行随机关联效率更高
坏处:一条语句分多条,增加连接开销

排序优化
无论如何,排序都是一个成本很高的操作,所以从性能角度考虑,尽可能避免排序,或避免对大量数据进行排序
Mysql性能优化笔记的更多相关文章
- MySQL性能优化笔记整理
一.测试篇 1.测试目的,就是量化找出短板(基础参数配置) 2.测试三大指标 IOPS:每秒处理的IO请求数,即IO响应速度(注意和IO吞吐量的区别) QPS:每秒请求(查询)次数 TPS:每秒事务数 ...
- MySQL性能优化总结___本文乃《MySQL性能调优与架构设计》读书笔记!
一.MySQL的主要适用场景 1.Web网站系统 2.日志记录系统 3.数据仓库系统 4.嵌入式系统 二.MySQL架构图: 三.MySQL存储引擎概述 1)MyISAM存储引擎 MyISAM存储引擎 ...
- mysql性能优化学习笔记
mysql性能优化 硬件对数据库的影响 CPU资源和可用内存大小 服务器硬件对mysql性能的影响 我们的应用是CPU密集型? 我们的应用的并发量如何? 数量比频率更好 64位使用32位的服务器版本 ...
- 《MySQL性能优化篇》阅读笔记
建表的时候,不要用null赋默认值,如:字符串的设置'',数据类型的设为0,不要将null设为默认值. 在MySQL中没有 full [outer] join,用union代替 各种 JOIN SQL ...
- MySQL性能优化总结
一.MySQL的主要适用场景 1.Web网站系统 2.日志记录系统 3.数据仓库系统 4.嵌入式系统 二.MySQL架构图: 三.MySQL存储引擎概述 1)MyISAM存储引擎 MyISAM存储引擎 ...
- MySQL性能优化总结(转)
MySQL性能优化总结 一.MySQL的主要适用场景 1.Web网站系统 2.日志记录系统 3.数据仓库系统 4.嵌入式系统 二.MySQL架构图: 三.MySQL存储引擎概述 1)MyISAM存 ...
- Mysql - 性能优化之子查询
记得在做项目的时候, 听到过一句话, 尽量不要使用子查询, 那么这一篇就来看一下, 这句话是否是正确的. 那在这之前, 需要介绍一些概念性东西和mysql对语句的大致处理. 当Mysql Server ...
- Mysql性能优化三(分表、增量备份、还原)
接上篇Mysql性能优化二 对表进行水平划分 如果一个表的记录数太多了,比如上千万条,而且需要经常检索,那么我们就有必要化整为零了.如果我拆成100个表,那么每个表只有10万条记录.当然这需要数据在逻 ...
- [MySQL性能优化系列]提高缓存命中率
1. 背景 通常情况下,能用一条sql语句完成的查询,我们尽量不用多次查询完成.因为,查询次数越多,通信开销越大.但是,分多次查询,有可能提高缓存命中率.到底使用一个复合查询还是多个独立查询,需要根据 ...
随机推荐
- 2016-2017 ACM-ICPC Pacific Northwest Regional Contest (Div. 1) Problem K Tournament Wins
Problem K — limit 1 second Tournament Wins 这个题就是有2^n队伍,他现在的实力水平是第k位,采用的是淘汰制 问一下你他的胜场数的期望 这人能 win> ...
- 【JavaScript 10—应用总结】:连缀
一.总体概述 1.1,什么叫连缀 所谓连缀,最简单的理解就是一句话同时设置一个或多个节点两个或两个以上的操作.比如: <span style="font-size:18px;" ...
- HDU-5317 RGCDQ ,暴力打表!
RGCDQ 暴力水题,很可惜比赛时没有做出来,理清思路是很简单的. 题意:定义f(i)表示i的素因子个数,给你一段区间[l,r],求max_gcd(f(i),f(j)).具体细节参考题目. 思路:数据 ...
- HDU-4738 Caocao's Bridges,注意重边不是桥!
Caocao's Bridges 题意:曹操赤壁之战后卷土重来,他在n个小岛之间建立了m座桥.现在周瑜只有一颗炮弹,他只能炸毁一座桥使得这些岛屿不再连通.每座桥上都可能会有士兵把手,如果想安放***那 ...
- lvs+keepalive主从和主主架构
下面配置主从 1)关闭SELinux和防火墙 vi /etc/sysconfig/selinux SELINUX=disabled setenforce 临时关闭SELinux,文件配置后,重启生效 ...
- 集群高可用之lvs+keepalive
集群高可用之lvs+keepalive keepalive简介: 负载均衡架构依赖于知名的IPVS内核模块,keepalive由一组检查器根据服务器的健康情况动态维护和管理服务器池.keepalive ...
- HDU 1565 方格取数(1) ——插头DP
[题目分析] 其实直接状压就可以了. 但是有点闲,又写了一个可读性极差,智商低下,很(gou)好(pi)的代码 [代码] #include <cstdio> #include <cs ...
- 刷题总结——玉蟾宫(bzoj3039单调栈)
题目: Description 有一天,小猫rainbow和freda来到了湘西张家界的天门山玉蟾宫,玉蟾宫宫主蓝兔盛情地款待了它们,并赐予它们一片土地.这片土地被分成N*M个格子,每个格子里写着'R ...
- Mac 快速修改 hosts 文件
sudo /Applications/TextEdit.app/Contents/MacOS/TextEdit /etc/hosts
- django学习之- simple_tag
如何将前端的数据直接通过python模块进行渲染,使用django的simple_tag功能,如下 django后端编写: 1:在对应的app目录下创建目录:templatetags 2:在templ ...