当前位置:  数据库>mysql

MySQL查询优化:连接查询排序浅谈

    来源: 互联网  发布时间:2014-10-08

    本文导语:  情况是这么一个情况:现在有两张表,team表和people表,每个people属于一个team,people中有个字段team_id。 下面给出建表语句: 代码如下:create table t_team(id int primary key,tname varchar(100)); create table t_people(id int primary key,pname varchar(100)...

情况是这么一个情况:现在有两张表,team表和people表,每个people属于一个team,people中有个字段team_id。


下面给出建表语句:

代码如下:

create table t_team
(
id int primary key,
tname varchar(100)
);

create table t_people
(
id int primary key,
pname varchar(100),
team_id int,
foreign key (team_id) references t_team(id)
);


下面我要连接两张表查询出前10个people,按tname排序。

于是,一个SQL语句诞生了:select * from t_people p left join t_team t onp.team_id=t.id order by p.pname limit 10; [语句①]


这个是我第一反应写的SQL,通俗易懂,也是大多数人的第一反应。

然后来测试一下这个语句的执行时间。

首先要准备数据。我用存储过程在t_team表中生成1000条数据,在t_people表中生成100000条数据。(存储过程在本文最后)

执行上面那条SQL语句,执行了好几次,耗时在3秒左右。

再换两个语句对比一下:   

1.把order by子句去掉:select * from t_people p left join t_team t on p.team_id=t.id limit10; [语句②]

耗时0.00秒,忽略不计。

2.还是使用order by,但是把连接t_team表去掉:select * from t_people p order by p.pname limit 10;  [语句③]

耗时0.15秒左右。

对比发现[语句①]的效率巨低。

为什么效率这么低呢。[语句②]和[语句③]执行都很快,[语句①]不过是二者的结合。如果先执行[语句③]得到排序好的10条people结果后,再连接查询出各个people的team,效率不会这么低。那么只有一个解释:MySQL先执行连接查询,再进行排序。


解决方法:如果想提高效率,就要修改SQL语句,让MySQL先排序取前10条再连接查询。

SQL语句:

select * from (select * from t_people p order by p.pname limit 10) p left join t_team t on p.team_id=t.id limit 10; [语句④]


[语句④]和[语句①]功能一样,虽然有子查询,虽然看起来很别扭,但是效率提高了很多,它的执行时间只要0.16秒左右,比之前的[语句①]提高了20倍。

这两个表的结构很简单,如果遇到复杂的表结构…我在实际开发中就碰到了这样的问题,使用[语句①]的方式耗时80多秒,但使用[语句④]只需1秒以内。


最后给出造数据的存储过程:

代码如下:

CREATE PROCEDURE createdata()
BEGIN
DECLARE i INT;
START TRANSACTION;
SET i=0;
WHILE i

    
 
 

您可能感兴趣的文章:

  • Mysql查询错误:ERROR:no query specified原因
  • mysql查询语句通过limit来限制查询的行数
  • Mysql设置查询条件(where)查询字段为NULL
  • mysql 开启慢查询 如何打开mysql的慢查询日志记录
  • mysql中查询当前正在运行的SQL语句并找出mysql中运行慢的sql语句
  • mysql 设置查询缓存
  • Mysql Select查询执行流程介绍及实例
  • MySQL 慢查询监控器 Anemometer
  • mysql的SQL_NO_CACHE(在查询时不使用缓存)和sql_cache用法
  • MySQL并行查询引擎 Shard-Query
  • Mysql大表查询优化技巧总结及案例分析
  • mysql自定义排序顺序语句 iis7站长之家
  • 在C中如何判断从mysql中查询到的NULL值?
  • php mysql查询指定范围内日期
  • mysql取当前时间与当前日期查询代码
  • MySQL运行状况查询方式介绍
  • 把mysql查询结果保存到文件的shell脚本
  • mysql 查询表中平均分最低的班级
  • mysql 跨表查询、更新、删除示例
  • mysql仿oracle的decode效果查询
  • php查询时间段 mysql时间查询
  • 数据库查询排序使用随机排序结果示例(Oracle/MySQL/MS SQL Server)
  • mysql中文排序注意事项与实现方法
  • mysql自定义排序顺序语句
  • mysql 按中文字段排序
  • 让MySQL支持中文排序的实现方法
  • mysql如何根据汉字首字母排序
  • MYSQL 关于两个经纬度之间的距离由近及远排序
  • Mysql select in 按id排序实现方法
  • mysql的中文数据按拼音排序的2个方法
  • mysql如何按照中文排序解决方案
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • mysql中如何查看最大连接数(max_connections)和修改最大连接数
  • 在线请教:linux下用MySQL C API 连接MySQL 4.1.12出现的连接问题,提示升级客户端!!!!!!
  • Myeclipse中自带Tomcat的JDBC连接池配置(mysql和mssql)
  • mysql密码过期导致连接不上mysql
  • php中内置的mysql数据库连接驱动mysqlnd简介及mysqlnd的配置安装方式
  • mysql开启远程连接(mysql开启远程访问)
  • mysql jdbc连接mysql数据库步骤及常见参数详解
  • 解决远程连接mysql很慢的方法(mysql_connect 打开连接慢)
  • Linux下的C++程序怎么连接WIN2000下的SQL Server 2000?或者如何连接MySQL?
  • mysql连接的空闲时间超过8小时后 MySQL自动断开该连接解决方案
  • windows mysql 客户端连接 VMWare中ubuntu里的MySQL
  • php连接不上mysql但mysql命令行操作正常的解决方法
  • JSP连接MySql/MS SQL Server/Oracle数据库连接方法[整理]
  • php连接mysql连接被重置怎么办?解决方法
  • mysql 里面的sql语句的连接字符是什么?急用!
  • 如何用java连接mysql数据库?
  • linux c远程连接MySql的问题
  • 测试php连接mysql是否成功的代码分享
  • 一个LIUNX的MYSQL连接问题
  • 如何解决连接mysql的权限问题?
  • linux下 mysql [设置或是连接]的问题
  • php安装完成后如何添加mysql扩展
  • 在 linux下输入"mysql"命令,进入mysql命令行,但出现“Can't connetc to local MySQL server thuough socket /var/lib/mysql/mysql.sock
  • MySQL Workbench的下载安装与使用教程
  • MySQL 重装MySQL后, mysql服务无法启动
  • VS2012+MySQL+SilverLight5的MVVM开发模式介绍
  • 为什么用linux安装盘安装了mysql后,启动mysql,提示找不到mysql.sock文件?
  • MySQL索引基本知识
  • 請教,在redhat linux7.2+mysql 中,系統提示mysql已啟動,網頁卻不能訪問mysql?
  • mysql中字符串和时间互相转换的方法(自动转换及DATE_FORMAT函数)
  • 求解释: useradd -g mysql mysql -d /home/mysql -s /sbin/nologin




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3