免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1564 | 回复: 6
打印 上一主题 下一主题

【已解决】还有Loose索引吗? [复制链接]

论坛徽章:
1
2015亚冠之本尤德科
日期:2015-06-05 17:25:48
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-09-20 10:18 |只看该作者 |倒序浏览
本帖最后由 cenalulu 于 2012-09-21 16:52 编辑

GROUP BY的实现,两种是在利用现有索引的情况下来完成group by的

一种是Loose索引实现

另外一种是Tight索引实现

Loose索引实现,执行计划的Extra:Using index for group-by

今天我在mysql 5.5中做测试,发现没有Extra:Using index for group-by。然道mysql5.5中的group by实现修改了?

论坛徽章:
8
CU大牛徽章
日期:2013-09-18 15:20:48CU大牛徽章
日期:2013-09-18 15:20:58CU大牛徽章
日期:2013-09-18 15:21:06CU大牛徽章
日期:2013-09-18 15:21:12CU大牛徽章
日期:2013-09-18 15:21:17天秤座
日期:2013-10-30 14:01:03摩羯座
日期:2013-11-29 18:02:31luobin
日期:2016-06-17 17:46:36
2 [报告]
发表于 2012-09-20 10:26 |只看该作者
group by的实现方式真没太多研究,等待大牛回答。

论坛徽章:
1
2015亚冠之本尤德科
日期:2015-06-05 17:25:48
3 [报告]
发表于 2012-09-20 10:39 |只看该作者
这是我做的例子:表结构,样式数据,索引,以及执行计划

表结构及数据:
CREATE TABLE group_message_2(
  id int(11) not null auto_increment,
  group_id int(11) not null,
  gmt_create datetime not null,
  user_id int(11) not null,
  author varchar(32) not null,
  subject varchar(12 not null,
  primary key (id)
);

insert into group_message_2 values(101,1, '2012-09-09 ',1,'jake','one monkey');
insert into group_message_2 values(102,1, '2012-09-11 ',1,'jake','one monkey');
insert into group_message_2 values(103,1, '2012-09-12 ',1,'jake','one monkey');
insert into group_message_2 values(104,1, '2012-09-13 ',2,'jake','one monkey');
insert into group_message_2 values(105,1, '2012-09-14 ',2,'jake','one monkey');
insert into group_message_2 values(106,2, '2012-09-14 ',2,'jake','one monkey');
insert into group_message_2 values(107,2, '2012-09-16 ',2,'jake','one monkey');
insert into group_message_2 values(108,2, '2012-09-14 ',2,'jake','one monkey');
insert into group_message_2 values(109,3, '2012-09-17 ',1,'jake','one monkey');
insert into group_message_2 values(110,3, '2012-09-16 ',1,'jake','one monkey');
insert into group_message_2 values(111,3, '2012-09-18 ',1,'jake','one monkey');
insert into group_message_2 values(112,3, '2012-09-17 ',1,'jake','one monkey');


创建索引:

Create index idx_gid_uid_gc on group_message_2(group_id,user_id,gmt_create)

查看执行计划:

Explain select user_id,max(gmt_create)
From group_message_2
Where group_id <10
Group by group_id ,user_id\G;

*************************** 1. row ***************************
           id: 1
  select_type: SIMPLE
        table: group_message_2
         type: index
possible_keys: idx_gid_uid_gc
          key: idx_gid_uid_gc
      key_len: 16
          ref: NULL
         rows: 12
        Extra: Using where; Using index
1 row in set (0.00 sec)


我希望出来的是Using index for group-by,结果是Using index。等待高手

论坛徽章:
0
4 [报告]
发表于 2012-09-20 14:49 |只看该作者
什么情况下出现Using index for group-by

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
5 [报告]
发表于 2012-09-20 18:41 |只看该作者
select user_id,max(gmt_create)
From group_message_2
Where group_id <10
Group by group_id ,user_id\G;

标红部分导致不能loose scan了。
去掉试试

论坛徽章:
0
6 [报告]
发表于 2012-09-21 15:27 |只看该作者
简朝阳的那本《Mysql性能调优与架构设计》,我也正在读,刚好看到这,同问!

论坛徽章:
0
7 [报告]
发表于 2012-09-21 15:44 |只看该作者
本帖最后由 chunhaicao 于 2012-09-21 16:04 编辑
Where group_id <10


将条件改为 where group_id = 10 的话
Extra:Using where;Using index for group-by
使用max/min这两个聚合函数满足loose索引扫描
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP