MySQL社区

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

搜索
查看: 7460|回复: 10
打印 上一主题 下一主题

[SQL类] 这样的sql语句怎么实现 (分组找出组内前3)

[复制链接]
1#
发表于 2013-5-8 11:24:15 | 显示全部楼层
你的意思应该是: 要找出前两项分组的情况下的第三项的前3 。

一哥们写了个SQL实现的很好:
  1. SELECT * FROM
  2. (SELECT @num := (SELECT COUNT(0) FROM test AS b WHERE b.kid = a.kid AND b.mid >= a.mid) AS num,
  3.         a.ver,a.kid,a.mid
  4.          FROM         test AS a) AS c
  5.   WHERE c.num <= 3
  6. ORDER BY c.kid DESC, c.mid DESC;
复制代码
2#
发表于 2013-5-8 14:03:21 | 显示全部楼层
附表结构及数据:
  1. CREATE TABLE `test` (
  2.   `ver` varchar(10) DEFAULT NULL,
  3.   `kid` int(11) DEFAULT NULL,
  4.   `mid` int(11) DEFAULT NULL
  5. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

  6. insert  into `test`(`ver`,`kid`,`mid`) values ('0.0.1',203,29),('0.0.1',203,4),('0.0.1',203,38),('0.0.1',203,86),('0.0.1',203,42),('0.0.1',203,546),('0.0.1',203,34),('0.0.1',204,15),('0.0.1',204,20),('0.0.1',204,371),('0.0.1',204,78),('0.0.1',204,57),('0.0.1',204,38),('0.0.1',204,960),(NULL,NULL,0);
复制代码
3#
发表于 2013-5-9 17:48:35 | 显示全部楼层
{:soso_e110:}
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|申请友链|小黑屋|Archiver|手机版|MySQL社区 ( 京ICP备07012489号   
联系人:周生; 联系电话:13911732319

GMT+8, 2024-5-6 03:28 , Processed in 0.066293 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表