mysql 分组统计

user表idnameval1a562b403a784b60......查找出a,b,..最高分所对应的记录如idnameval3a784b60......select*... user表
id name val
1 a 56
2 b 40
3 a 78
4 b 60
......

查找出a,b,..最高分所对应的记录如
id name val
3 a 78
4 b 60
......
select * from user group by name order by val desc 不能找到最高分
请问要怎么写这条语句
CREATE TABLE IF NOT EXISTS `user` (
`id` tinyint(2) NOT NULL,
`name` varchar(10) NOT NULL,
`val` int(11) NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

INSERT INTO `user` (`id`, `name`, `val`) VALUES
(1, 'a', 56),
(2, 'b', 40),
(3, 'a', 78),
(4, 'b', 60);
展开
 我来答
wgp701
2013-07-09 · TA获得超过380个赞
知道小有建树答主
回答量:477
采纳率:100%
帮助的人:233万
展开全部
SELECT (
SELECT s1.`id`
FROM `user` AS s1
WHERE s1.val=MAX(s.`val`)
)
AS id , s.`name` , MAX(s.`val`)
AS maxval
FROM `user` AS s
GROUP BY s.`name` ORDER BY s.val DESC
YLSDD
2013-07-09 · 超过43用户采纳过TA的回答
知道小有建树答主
回答量:150
采纳率:0%
帮助的人:97.7万
展开全部
其实很简单,select后面条件加上下面这个就可以了。
select id,name,max(val) from user group by name order by val desc
追问
id 不对
追答
select * from user where val in (select max(val) from user group by name) ;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
靓蕴久4418
2013-07-09 · TA获得超过143个赞
知道答主
回答量:128
采纳率:0%
帮助的人:120万
展开全部
select id,name, max(val) as val from user group by name;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式