全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Mysql数据库性能优化之子查询

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

那在这之前, 需要介绍一些概念性东西和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子查询优化方法详解  # 一句  # 都是  # 先看  # 基础上  # 小编  # 加起来  # 的是  # 之子  # 这一  # 是在  # 最多  # 在这  # 就有  # 在此  # 是由  # 是从  # 这句话  # 给大家  # 看他  # 能看 


相关文章: 制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?  教学网站制作软件,学习*后期制作的网站有哪些?  新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?  长沙做网站要多少钱,长沙国安网络怎么样?  创业网站制作流程,创业网站可靠吗?  建站org新手必看:2024最新搭建流程与模板选择技巧  小建面朝正北,A点实际方位是否存在偏差?  微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?  专业公司网站制作公司,用什么语言做企业网站比较好?  如何通过虚拟主机快速完成网站搭建?  C++中引用和指针有什么区别?(代码说明)  C++用Dijkstra(迪杰斯特拉)算法求最短路径  南京网站制作费用,南京远驱官方网站?  重庆市网站制作公司,重庆招聘网站哪个好?  如何快速搭建高效香港服务器网站?  如何在云主机上快速搭建网站?  建站之星IIS配置教程:代码生成技巧与站点搭建指南  建站之星CMS建站配置指南:模板选择与SEO优化技巧  建站之星后台管理:高效配置与模板优化提升用户体验  c# 在高并发下使用反射发射(Reflection.Emit)的性能  Python多线程使用规范_线程安全解析【教程】  股票网站制作软件,网上股票怎么开户?  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  网站制作价目表怎么做,珍爱网婚介费用多少?  音响网站制作视频教程,隆霸音响官方网站?  建站之星如何快速生成多端适配网站?  如何通过IIS搭建网站并配置访问权限?  文字头像制作网站推荐软件,醒图能自动配文字吗?  建站之星后台管理系统如何操作?  Swift中循环语句中的转移语句 break 和 continue  宝塔建站无法访问?如何排查配置与端口问题?  如何快速搭建高效可靠的建站解决方案?  网站建设设计制作营销公司南阳,如何策划设计和建设网站?  如何通过宝塔面板实现本地网站访问?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  外汇网站制作流程,如何在工商银行网站上做外汇买卖?  建站之星24小时客服电话如何获取?  如何选购建站域名与空间?自助平台全解析  c# 在高并发场景下,委托和接口调用的性能对比  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  无锡营销型网站制作公司,无锡网选车牌流程?  非常酷的网站设计制作软件,酷培ai教育官方网站?  如何在搬瓦工VPS快速搭建网站?  高防服务器租用如何选择配置与防御等级?  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  简单实现Android文件上传  制作证书网站有哪些,全国城建培训中心证书查询官网?  c++ stringstream用法详解_c++字符串与数字转换利器  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。