记得在做项目的时候, 听到过一句话, 尽量不要使用子查询, 那么这一篇就来看一下, 这句话是否是正确的.

那在这之前, 需要介绍一些概念性东西和mysql对语句的大致处理.
当Mysql Server的连接线程接收到Client发送过来的SQL请求后, 会经过一系列的分解Parse, 进行相应的分析, 然后Mysql会通过查询优化器模块, 根据该Sql所涉及到的数据表的相关统计信息进行计算分析. 然后在得出一个Mysql自认为最合理最优化的数据访问方式, 也就是我们常说的"执行计划", 然后根据所得到的执行计划通过调用存储引擎接口来获取相应数据. 再对存储引擎返回的数据进行相关的处理, 并一Client端所要求的格式作为结果集, 返回给Client.
注 : 这里所说的统计数据, 是我们通过 Analyze table命令通知Mysql对表的相关数据作分析之后, 所获取到的一些数据统计量. 这些数据对Mysql优化器而言是非常重要的, 优化器所生成的执行计划的好坏, 主要是由这些统计数据所决定的.
1. 建表
create table User( Id int not null PRIMARY key auto_increment , NickName varchar(50) comment '用户昵称', Sex int comment '性别', Sign varchar(50) comment '用户签名', Birthday datetime comment '用户生日', CreateTime datetime comment '创建时间' ) default charset=utf8 comment '用户表'; create table UserGroup( Id int not null PRIMARY key auto_increment , UserId int not null comment 'user Id', GroupId int not null comment '用户组Id', CreateTime datetime comment '创建时间', -- key index_groupid(GroupId) using btree, key index_userid(groupid, UserId) using btree ) default charset=utf8 comment '用户组表';
2. 准备数据
var conStr = ConfigurationManager.ConnectionStrings["ConStr"].ToString();
using (IDbConnection conn = new MySqlConnection(conStr))
{ Stopwatch watch = new Stopwatch();
var sql = string.Empty;
var names = new string[] { "非", "想", "红", "帝", "德", "看", "梅", "插", "兔" };
Random ran = new Random();
var insertSql = @" insert into User(NickName,Sex,Sign, Birthday, CreateTime) values(@NickName,@Sex,@Sign, @Birthday, @CreateTime);
INSERT INTO usergroup (UserId, GroupId, CreateTime ) VALUES (LAST_INSERT_ID() , @GroupId, @CreateTime);";
watch.Start();
if (conn.State == ConnectionState.Closed)
{
conn.Open();
}
var tran = conn.BeginTransaction();
for (int i = 0; i < 100000; i++)
{
var param = new { NickName = names[ran.Next(9)] + names[ran.Next(9)] + i, Sign = names[ran.Next(9)] + names[ran.Next(9)], CreateTime = DateTime.Now, Birthday = DateTime.Now.AddYears(ran.Next(10, 30)), Sex = i % 2, GroupId = ran.Next(1, 100) };
conn.Execute(insertSql, param, tran);
}
tran.Commit();
conn.Dispose();
watch.Stop();
Console.WriteLine(watch.ElapsedMilliseconds);
}
这里我插入了5000条数据, group分了99个组, 随机的.
3. 查询sql
explain select user.id, user.nickname from usergroup left join user on usergroup.UserId = user.Id where usergroup.groupid = 1 order by usergroup.UserId desc limit 100, 20; explain select user.id, user.nickname from (select id, userid from usergroup where groupid = 1 order by userid limit 100, 20) t left join user on t.UserId = user.id ; explain select user.id, user.nickname from (select id, userid from usergroup where groupid = 1 order by userid ) t left join user on t.UserId = user.id limit 100, 20;
第二句和第三句都使用到了子查询, 不同之处再与, 第二句是先得到20条数据, 然后以此来与user表关联的
4. 分析
100000条数据情况下 :
先看第一句
再看第二句
第三句
从上面三幅图看, 好像能看出点什么了.
首先看他们的 rows, 第二句最多, 加起来有1000多了, 另两句加起来都是996. 但是我想说的是, 这里并不是看rows的和是多少. 正确的方式是, 从id大的语句开始看, id相同的语句, 从上到下依次执行.
那先看第二句的id=2的语句和第一句的id=1的语句, 一模一样的. 他们都是从usergroup表中筛选数据, 并且能得到相同的结果集A.
看来他们都是基于相同的结果集去进行操作, 接下来就有区别了.
先看第一句, 再结果集A的基础上, 去左连接表user, 并筛选出最后的数据, 返回给客户端.
那第二句呢, 是在A的基础上, 再次筛选数据, 得到需要的数据, 然后拿这些数据, 去与user表左连接, 得到最终结果.
从上面来看, 执行计划中, 第二种执行计划, 更加高效.
如果能够通过子查询, 大幅度缩小查询范围, 可以考虑使用子查询语句.
以上所述是小编给大家介绍的Mysql数据库性能优化之子查询,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# mysql
# 性能优化
# 子查询
# mysql in语句子查询效率慢的优化技巧示例
# MYSQL子查询和嵌套查询优化实例解析
# 浅谈MySQL中的子查询优化技巧
# MySql子查询IN的执行和优化的实现
# MySQL的子查询及相关优化学习教程
# Mysql查询优化之IN子查询优化方法详解
# 一句
# 都是
# 先看
# 基础上
# 小编
# 加起来
# 的是
# 之子
# 这一
# 是在
# 最多
# 在这
# 就有
# 在此
# 是由
# 是从
# 这句话
# 给大家
# 看他
# 能看
相关文章:
网站制作免费,什么网站能看正片电影?
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
小型网站建站如何选择虚拟主机?
在线教育网站制作平台,山西立德教育官网?
如何在橙子建站上传落地页?操作指南详解
如何选择最佳自助建站系统?快速指南解析优劣
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
C++如何编写函数模板?(泛型编程入门)
小说建站VPS选用指南:性能对比、配置优化与建站方案解析
实现虚拟支付需哪些建站技术支撑?
建站之星如何助力企业快速打造五合一网站?
如何在万网自助建站中设置域名及备案?
建站之星代理平台如何选择最佳方案?
浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
如何用PHP快速搭建高效网站?分步指南
建站主机解析:虚拟主机配置与服务器选择指南
如何用y主机助手快速搭建网站?
青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?
制作网站怎么制作,*游戏网站怎么搭建?
如何通过VPS建站无需域名直接访问?
如何通过主机屋免费建站教程十分钟搭建网站?
教程网站设计制作软件,怎么创建自己的一个网站?
,有什么在线背英语单词效率比较高的网站?
如何高效利用200m空间完成建站?
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
建站之星CMS建站配置指南:模板选择与SEO优化技巧
如何通过虚拟主机空间快速建站?
学校免费自助建站系统:智能生成+拖拽设计+多端适配
C++如何使用std::optional?(处理可选值)
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
C#怎么使用委托和事件 C# delegate与event编程方法
网站建设设计制作营销公司南阳,如何策划设计和建设网站?
如何在Golang中使用encoding/gob序列化对象_存储和传输数据
北京建设网站制作公司,北京古代建筑博物馆预约官网?
广州营销型建站服务商推荐:技术优势与SEO优化解析
宝华建站服务条款解析:五站合一功能与SEO优化设置指南
c# 在ASP.NET Core中管理和取消后台任务
建站之星如何实现PC+手机+微信网站五合一建站?
建站之星上传入口如何快速找到?
洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?
建站之星如何一键生成手机站?
如何用狗爹虚拟主机快速搭建网站?
微信推文制作网站有哪些,怎么做微信推文,急?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
c# 服务器GC和工作站GC的区别和设置
无锡营销型网站制作公司,无锡网选车牌流程?
网站制作的步骤包括,正确网址格式怎么写?
天津个人网站制作公司,天津网约车驾驶员从业资格证官网?
济南企业网站制作公司,济南社保单位网上缴费步骤?
*请认真填写需求信息,我们会在24小时内与您取得联系。