一,索引

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性能优化笔记的更多相关文章

  1. MySQL性能优化笔记整理

    一.测试篇 1.测试目的,就是量化找出短板(基础参数配置) 2.测试三大指标 IOPS:每秒处理的IO请求数,即IO响应速度(注意和IO吞吐量的区别) QPS:每秒请求(查询)次数 TPS:每秒事务数 ...

  2. MySQL性能优化总结___本文乃《MySQL性能调优与架构设计》读书笔记!

    一.MySQL的主要适用场景 1.Web网站系统 2.日志记录系统 3.数据仓库系统 4.嵌入式系统 二.MySQL架构图: 三.MySQL存储引擎概述 1)MyISAM存储引擎 MyISAM存储引擎 ...

  3. mysql性能优化学习笔记

    mysql性能优化 硬件对数据库的影响 CPU资源和可用内存大小 服务器硬件对mysql性能的影响 我们的应用是CPU密集型? 我们的应用的并发量如何? 数量比频率更好 64位使用32位的服务器版本 ...

  4. 《MySQL性能优化篇》阅读笔记

    建表的时候,不要用null赋默认值,如:字符串的设置'',数据类型的设为0,不要将null设为默认值. 在MySQL中没有 full [outer] join,用union代替 各种 JOIN SQL ...

  5. MySQL性能优化总结

    一.MySQL的主要适用场景 1.Web网站系统 2.日志记录系统 3.数据仓库系统 4.嵌入式系统 二.MySQL架构图: 三.MySQL存储引擎概述 1)MyISAM存储引擎 MyISAM存储引擎 ...

  6. MySQL性能优化总结(转)

    MySQL性能优化总结   一.MySQL的主要适用场景 1.Web网站系统 2.日志记录系统 3.数据仓库系统 4.嵌入式系统 二.MySQL架构图: 三.MySQL存储引擎概述 1)MyISAM存 ...

  7. Mysql - 性能优化之子查询

    记得在做项目的时候, 听到过一句话, 尽量不要使用子查询, 那么这一篇就来看一下, 这句话是否是正确的. 那在这之前, 需要介绍一些概念性东西和mysql对语句的大致处理. 当Mysql Server ...

  8. Mysql性能优化三(分表、增量备份、还原)

    接上篇Mysql性能优化二 对表进行水平划分 如果一个表的记录数太多了,比如上千万条,而且需要经常检索,那么我们就有必要化整为零了.如果我拆成100个表,那么每个表只有10万条记录.当然这需要数据在逻 ...

  9. [MySQL性能优化系列]提高缓存命中率

    1. 背景 通常情况下,能用一条sql语句完成的查询,我们尽量不用多次查询完成.因为,查询次数越多,通信开销越大.但是,分多次查询,有可能提高缓存命中率.到底使用一个复合查询还是多个独立查询,需要根据 ...

随机推荐

  1. 九度oj 题目1256:找出两个只出现了一次的数字

    题目描述: 一个整型数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字. 输入: 输入的第一行包括一个整数N(1<=N<=1000). 接下来的一行包括N个 ...

  2. 使用python实现简单的爬虫

    python爬虫的简单实现 开发环境的配置 python环境的安装 编辑器的安装 爬虫的实现 包的安装 简单爬虫的初步实现 将数据写入到数据库-简单的数据清洗-数据库的连接-数据写入到数据库 开发环境 ...

  3. ngrinder的idea脚本开发环境配置

    1.安装toriseSvn,安装一定要选择comandline (默认是没选择的) 2.下载groovy,解压缩,在开发工具(ps:idea,eclipse)中设置groovy安装路径 3.在网站处创 ...

  4. UVa10539

    http://vjudge.net/problem/UVA-10539 先打出来sqrt(n)以内的素数表,然后对于每个素数x,他对答案的贡献就是最大的p使x^p<=n,即log(x,n).注意 ...

  5. 洛谷——P1025 数的划分

    P1025 数的划分 题目描述 将整数n分成k份,且每份不能为空,任意两个方案不相同(不考虑顺序). 例如:n=7,k=3,下面三种分法被认为是相同的. 1,1,5; 1,5,1; 5,1,1; 问有 ...

  6. luogu P2085 最小函数值

    题目描述 有n个函数,分别为F1,F2,...,Fn.定义Fi(x)=Ai*x^2+Bi*x+Ci (x∈N*).给定这些Ai.Bi和Ci,请求出所有函数的所有函数值中最小的m个(如有重复的要输出多个 ...

  7. RMA Sales Order – Stuck with “Awaiting Return Disposition”

    RMA Sales Order – Stuck with “Awaiting Return Disposition” Action : (Prod) ð  Login to Unix ð  su – ...

  8. Hijacking FM Radio with a Raspberry Pi & Wire

    转载:https://null-byte.wonderhowto.com/how-to/hack-radio-frequencies-hijacking-fm-radio-with-raspberry ...

  9. C++字符串转数字,数字转字符串

    1. 字符串转数字 如将"32"转为32,将"3.1415"转为3.1415,将"567283"转为567283.使用: //Convert ...

  10. 前端高频面试题 CSS篇

    通过从网上看到的面经,总结的一些高频的前端CSS面试题,有很多不会,于是找资料,并通过代码实现,自己提供了一些参考答案. 目录 1.怎样会产生浮动? 2.如何清除浮动? 3.盒子模型,以及IE和其他浏 ...