sql优化个人总结(全)
只会写if...else的程序员。
查询,统计和汇总。由于数据量比较庞大,大部分表数据上百万,甚至有的表数据上千万。所以
在系统中做sql优化比较多,特此写一篇博客总结一下关于sql优化方面的经验。
1、数据量过大
-- 针对SQL语句的优化
(在确认没有重复数据或者不用剔除重复数据时,union all会更好)
后台开定时任务将数据先统计好,尽量不要在查询的时候去统计)
-- 索引优化
--说索引前先说说explain查看sql的执行计划
SELECT识别符。这是select查询序列号。这个不重要
表示查询中每个select子句的类型(简单OR复杂)
有以下几种值:
1 simple
查询中不包含查询或者UNION(联合查询)
2 PRIMARY
查询中若包含任何复杂的子部分,最外层查询则被标记为:PRIMARY
3 UNION
表示连接查询的第2个或后面的查询语句。
4 DEPENDENT UNION
UNION 中的第二个或者后面的select语句,取决于外面的查询
5 UNION RESULT
连接查询的结果
6 SUBQUERY
子查询中的第一个select语句
7 DEPENDENT SUBQUERY
子查询中的第一个select语句,取决于外面的查询
8 DERIVED
select(from子句的子查询)
表示表的连接类型
以下的连接类型的顺序是从最佳类型到最差类型
1 syste
表仅有一行,这是const类型的特例,平时不会出现
2 const
数据表最多只有一个匹配行,因为只匹配一行数据,所以很快,常用于PRIMARY KEY
或者UNIQUE查询,可理解为是最优化的。
3 eq_ref
mysql手册是这样说的: 对于每个来自前面的表的行组合,从该表中读取一行。
这可能是最好的联接类型,除了const类型。他用在一个索引的所有部分被联接使用并且并且索引是UNIQUE或PRIMARY KEY eq_ref可以用于使用=比较带索引的列。
查询条件索引既不是UNIQUE 也不是PRIMARY KEY 的情况,ref可用于=或<或>操作符的带索引的列。
该联接类型如同ref,但是添加了Mysql可以专门搜索包含null值的行,在解决子查询中经常使用该联接类型的优化。
该连接类型与ALL相同,除了只有索引树被扫描。这通常比ALL快,因为索引文件通常比数据文件小。
对于每个来自先前的表的行组合,进行完整的表扫描。
指出Mysql能使用哪个索引在该表中找到行。
如果该列为NULL 说明没有使用索引,可以对该列创建索引来提高性能
6 Key
显示mysql实际决定使用的索引,如果没有选择索引,键是null
可以强制使用索引或者忽略索引:
强制使用索引:USE index(列名)
忽略使用索引:IGNORE INDEX(列名)
7 key_len
显示mysql决定使用的键长度。如果键是NULL则长度为NULL。
注意:key_len 是确定了mysql将实际使用的索引长度
显示使用哪个列或常数与key一起从表中选择行
9 rows
显示mysql认为它执行查询时必须检查的行数
10 extra
关于MYSQL如何解析查询的额外信息。Using temporary和Using filesort,意思MYSQL根本不能使用索引,结果是检索会很慢
说明:extra列返回的描述的意义
Distinct :一旦mysql找到了与行相联合匹配的行,就不再搜索了。
Not exists :mysql优化了LEFT JOIN,一旦它找到了匹配LEFT JOIN标准的行,就不再搜索了。
Range checked for each Record(index map:#) :没有找到理想的索引,因此对从前面表中来的每一个行组合,mysql检查使用哪个索引,并用它来从表中返回行。这是使用索引的最慢的连接之一。
Using filesort :看到这个的时候,查询就需要优化了。mysql需要进行额外的步骤来发现如何对返回的行排序。它根据连接类型以及存储排序键值和匹配条件的全部行的行指针来排序全部行。
Using index :列数据是从仅仅使用了索引中的信息而没有读取实际的行动的表返回的,这发生在对表的全部的请求列都是同一个索引的部分的时候。
Using temporary :看到这个的时候,查询需要优化了。这里,mysql需要创建一个临时表来存储结果,这通常发生在对不同的列集进行ORDER BY上,而不是GROUP BY上。
Where used :使用了WHERE从句来限制哪些行将与下一张表匹配或者是返回给用户。如果不想返回表中的全部行,并且连接类型ALL或index,这就会发生,或者是查询有问题。
--使用索引时有些不生效的情况
4、尽量避免在where子句中使用!=或<>操作符,否则引擎将放弃使用索引而进行全表扫描。
应改为:
select id from t where num=100*2
7、尽量避免在where子句中对字段进行函数操作,将导致引擎放弃使用索引而进行全表扫描。
sex,male,female几乎个一半,那么即使在sex上建立了索引也对查询效率起不了作用。
若太多则应考虑一些不常使用到的列上建的索引是否有 必要。
2、如果有where 条件,比如where vtype=1 order by vtype asc . 这样order by 也会用到索引!
转载于:https://www.cnblogs.com/telwanggs/p/10792163.html
sql优化个人总结(全)相关推荐
- 史上最全SQL优化方案
点击上方 好好学java ,选择 星标 公众号 重磅资讯.干货,第一时间送达今日推荐:2020年7月程序员工资统计,平均14357元,又跌了,扎心个人原创100W+访问量博客:点击前往,查看更多 作者 ...
- 史上最全的 SQL 优化方案!建议收藏
在进行MySQL的优化之前,必须要了解的就是MySQL的查询过程,很多查询优化工作实际上就是遵循一些原则,让MySQL的优化器能够按照预想的合理方式运行已. 图-MySQL查询过程 1 优化的哲学 注 ...
- SQL数据库不用SQL语句能显示全表的内容_详解mysql数据库sql优化技巧总结
概述 关于SQL优化的教程很多,但是比较杂乱.所以抽空整理了一下,也写出来跟大家分享一下.以下主要针对MySQL数据库,Oracle数据库也可以参考. 优化技巧总结 1.建索引 对查询进行优化,要尽量 ...
- 拼装sql_2020最新最全面的SQL优化干货总结
作者:_陈哈哈原文:https://sohu.gg/FGG98i BATJTMD 等大厂的面试难度越来越高,但无论从大厂还是到小公司,一直不变的重点就是对 SQL 优化经验的考察.一提到数据库,面试官 ...
- mysql存储过程更新数据后返回一个字段_史上最全存储引擎、索引使用及SQL优化的实践...
整个MySQL Server由以下组成 : Connection Pool :连接池组件 Management Services & Utilities :管理服务和工具组件 SQL Inte ...
- 最全的 SQL 优化方案
转自:https://www.cnblogs.com/clsn/p/8214048.html 1.1 前言 在进行MySQL的优化之前必须要了解的就是MySQL的查询过程,很多的查询优化工作实际上就是 ...
- 史上最全SQL优化方案(二)
接上篇!! 4 基础优化 a 优化思路 定位问题点吮吸:硬件–>系统–>应用–>数据库–>架构(高可用.读写分离.分库分表). 处理方向:明确优化目标.性能和安全的折中.防患未 ...
- 中秋节,送上一次非常有趣的SQL优化实战经历
点击上方"搜云库技术团队",选择"设为星标" 回复"1024"或"面试题"获取4T学习资料 补充:看到好多朋友后台留言说 ...
- MySQL进阶SQL优化
MySQL进阶SQL优化 查询效率分析: 子查询为确保消除重复值,必须为外部查询的每个结果都处理嵌套查询.在这种情况下可以考虑用联接查询来取代. 如果要用子查询,那就用EXISTS替代IN.用NOT ...
最新文章
- 代码编辑神器VIM(附我写acm程序时的配置)(转)
- Transformer温故知新
- Android中的Broadcast Action大全
- struts1跳入指定方法
- Linux 关机/关闭主机/关闭系统/重启系统/注销系统的命令
- [react] 你用过react版本有哪些?
- 麻省理工MIT发布首个贝叶斯「数据清洗」机器人!
- python日期,从int格式为时间格式
- 邮政管理部门发话:未获用户同意投放快递柜属违法行为
- Ubuntu16.04 下convert 命令 将eps转tif,jpg,png,pdf格式
- Apex 获取真正的IP地址
- C++windows环境管道通信
- h5中的结构元素header、nav、article、aside、section、footer介绍
- 计算机网络五层模型详解
- 面经分享:网友问我,怎样才能在谷歌匹兹堡办公室里写代码?下篇
- python中abbab什么意思_ABtest与Python代码-Go语言中文社区
- matlab normx-x0_【 MATLAB 】norm ( Vector and matrix norms )(向量范数以及矩阵范数)
- linux手机版模拟电脑,在你的PC上体验Firefox OS 1.3 模拟器
- vs快捷键:ctor+双击Tab,快速生成构造函数
- [原创]找小丑-你要做小丑,还是主宰小丑的那个?
热门文章
- CTF入门--题目介绍
- Spark源码分析之Master资源调度算法原理
- (98)利用函数function实现半字节加法功能,面试必问(二十二)(第20天)
- (16)System Verilog联合体union详解
- ZYNQ FPGA控制LED灯不闪烁
- bat 复制文件夹_一个神奇的bat批处理文件,更好的隐藏电脑里的文件或者文件夹...
- active mq topic消费后删除_RabbitMQ的常见队列模型:simple、work、fanout、direct、topic等等...
- 【STM32】FLASH擦写+FLASH相关操作+注意事项
- 傅里叶变换 c语言程序,(快速傅里叶变换)C语言程序汇编
- 利用ffmpeg提供的库(API)进行音频与视频的编码并生成文件