免费注册 查看新帖 |

Chinaunix

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

Mysql中MAX函数的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-12-01 15:52 |只看该作者 |倒序浏览
+-----------+------+-------+
| course    | num  | score |
+-----------+------+-------+
| 数学    | 1001 |    80 |
| 语文    | 1001 |    90 |
| 英语    | 1001 |    85 |
| 计算机 | 1001 |    95 |
| 数学    | 1002 |    88 |
| 语文    | 1002 |    90 |
| 英语    | 1002 |    89 |
| 计算机 | 1002 |    90 |
| 数学    | 1003 |    80 |
| 语文    | 1003 |    98 |
| 英语    | 1003 |    85 |
| 计算机 | 1003 |    95 |
+-----------+------+-------+

数据如上面的表格所示,执行下列语句:
SELECT course,num,MAX(score) FROM grade GROUP BY course;
执行结果如下:
+-----------+------+------------+
| course    | num  | MAX(score) |
+-----------+------+------------+
| 英语    | 1001 |         89 |
| 计算机 | 1001 |         95 |
| 语文    | 1001 |         98 |
| 数学    | 1001 |         88 |
+-----------+------+------------+

num字段没有与上表中的 MAX(score)相对应,如英语 89 的的num应为1002。
我是新手,望高手指点一二。

论坛徽章:
2
酉鸡
日期:2014-02-19 09:11:08摩羯座
日期:2014-05-23 10:16:16
2 [报告]
发表于 2013-12-01 16:49 |只看该作者
你上面的写法虽然没报语法错误,但是错误的,数据给你弄错位了,结果全乱了
  1. SELECT course,num,MAX(score) FROM grade GROUP BY course,num ;
复制代码

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
3 [报告]
发表于 2013-12-02 10:37 |只看该作者
这个问题论坛上有很多讨论的啦,好像谁还有一个文章特别讨论的。印象里你这个问题可以这样处理,没测试,你试试:

  1. SELECT course,num,MAX(score)
  2. FROM
  3. ( select * from grade order by score desc) as tmp
  4. GROUP BY course;
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP