”MySQL查询优化“学习总结
查询优化有几种方法,下面分别介绍。
切分查询
- 一条大的语句(涉及很多行)一次会锁住很多数据(不利于高并发)。
 - 占满整个事务日志,耗尽系统资源、阻塞很多小的但很重要的查询。
 
分解关联查询
关联查询分解方法:对每一个表进行一次单表查询,然后将结果在应用程序中进行关联。这样做的好处有:
- 让缓存效率更高,应用程序可以很方便地缓存单表查询的结果对象。
 - 将查询分解后,执行单个查询可以减少锁的竞争。
 - 在应用层做关联,可以更容易地对数据库进行拆分,更容易做到高性能和可拓展。
 - 查询本身的效率也可能提升。
 - 可以减少冗余记录的查询。在应用层做关联查询,意味着对于某条记录应用只需要查询一次。
 - 在应用层中做关联,相当于在应用中实现了查询数据的哈希关联,而不是使用MySQL的嵌套循环关联。从数据结构上优化了查询的时间复杂度。
 
通过重构查询——将关联查询放到应用程序中——将会更加高效。
MySQL客户端/服务器通信协议
MySQL客户端与服务器之间的通信协议是“半双工”的。
”MySQL查询优化“学习总结的更多相关文章
- mysql深入学习(一)
		
Mysql高级学习 一.Mysql简介 1.概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同 ...
 - Atitit Mysql查询优化器 存取类型 范围存取类型 索引存取类型 AND or的分析
		
Atitit Mysql查询优化器 存取类型 范围存取类型 索引存取类型 AND or的分析 Atitit Mysql查询优化器 存取类型 范围存取类型 索引存取类型 AND or的分析1 存 ...
 - MySQL查询优化之explain的深入解析
		
在分析查询性能时,考虑EXPLAIN关键字同样很管用.EXPLAIN关键字一般放在SELECT查询语句的前面,用于描述MySQL如何执行查询操作.以及MySQL成功返回结果集需要执行的行数.expla ...
 - MySQL事务学习-->隔离级别
		
MySQL事务学习-->隔离级别 6 事务的隔离级别 设置的目的 在数据库操作中,为了有效保证并发读取数据的正确性,提出的事务隔离级别. 数据库是要被广大客户所共享访问的,那么在数据库操作过程中 ...
 - 1025WHERE执行顺序以及MySQL查询优化器
		
转自http://blog.csdn.net/zhanyan_x/article/details/25294539 -- WHERE执行顺序-- 过滤比较多的放在前面,然后更加容易匹配,从左到右进行执 ...
 - MySQL查询优化:查询慢原因和解决技巧
		
在开发的朋友特别是和mysql有接触的朋友会碰到有时mysql查询很慢,当然我指的是大数据量百万千万级了,不是几十条了,下面我们来看看解决查询慢的办法. MySQL查询优化:查询慢原因和解决方法 会经 ...
 - mysql查询优化器为什么可能会选择错误的执行计划
		
有可能导致mysql优化器选择错误的执行计划的原因如下: A:统计信息不准确,mysql依赖存储引擎为其提供的统计信息来评估成本,然而有的存储引擎提供的信息是准确的,有的引擎提供的可能就偏差很大,如: ...
 - MySQL数据库学习笔记(十二)----开源工具DbUtils的使用(数据库的增删改查)
		
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
 - MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类
		
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
 
随机推荐
- Docker 学习应用篇之三: Docker的简单实用
			
安装完Docker之后,我们就可以简单的使用Docker,来体会Docker的用处. 首先看下Docker的常用命令,都是我在实用Docker的时候用到的命令: docker常用命令: $ docke ...
 - 深圳MPD大会,五大专题一会尽享
			
深圳MPD大会,五大专题一会尽享 2013年9月,深圳的高温将慢慢褪去,炎炎夏日也会变得稍微清凉一些.但9月It届的峰会活动却没有丝毫的锐减.9月7-8日深圳将迎来MPD大会2013的收官之站. MP ...
 - Java Eclipse编译后产生的字节码文件,用DOS命令符怎么打开
			
在很多初学者刚刚接触eclipse的时候,写完一个代码文件.例如 Demo.java 通过run as a java application生成之后,会产生一个Demo.class. Demo.cla ...
 - 2016江苏省CPC省赛 I - Itinerary Planning
			
Description Mike moved to a new city. There are bus stations in the city, each has a unique name. Ea ...
 - referrer privacy hotlinking
			
https://en.wikipedia.org/wiki/HTTP_referer https://zh.wikipedia.org/wiki/HTTP参照位址 inline linking, of ...
 - anti-VM tech
			
反虚拟机技术 版权声明:本文为博主原创文章,未经博主允许不得转载. 1:浮点运算的花指令 如果不是花指令则更好了 2:借助EPO思想,解密函数远离入口点 3:多线程技术 4:SEH技术 5:元多形 ...
 - mysql数据库的相关练习题及答案
			
表结构示意图: 表结构创建语句: class表创建语句 create table ) not null)engine=innodb default charset=utf8; student表创建语句 ...
 - startuml 2.6注册
			
参考:http://bbs.chinapyg.com/thread-79022-1-1.html 各平台版本均适用,本文更改的为Mac版本. 1,打开对应 mac版本的安装包位置,在对应目录/App ...
 - CentOS VmwareTools安装
			
1. 虚拟机菜单栏--虚拟机--安装VMware tools 2. CentOS系统中弹出的VMware tools窗口中--右击VMwaretools.tar.gz--Extract到桌面 3.打开 ...
 - java NIO (二) 一个故事讲清楚NIO
			
假设某银行只有10个职员.该银行的业务流程分为以下4个步骤: 1) 顾客填申请表(5分钟): 2) 职员审核(1分钟): 3) 职员叫保安去金库取钱(3分钟): 4) 职员打印票据,并将钱和票据返回给 ...