如何解决mysql group by问题

发布时间:2021-10-14 14:39:15 作者:iii
来源:亿速云 阅读:115

本篇内容介绍了“如何解决mysql  group by问题 ”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

数据表如下: 

如何解决mysql  group by问题

需求统计每个部门谁的工资最高。

错误的sql     select NAME,desp, MAX(price) from show_plan  GROUP BY  desp

如何解决mysql  group by问题

name , desp  都是第一条数据。。。 

正确的语句:  使用临时表。  第一次按照price desc 排序 。

drop TABLE tmp3 ;
CREATE TABLE tmp3 (SELECT * from show_plan ORDER BY price DESC ) ;
SELECT  *  from tmp3 GROUP BY desp

很奇怪如下的sql 结果不正确。

SELECT  * from (SELECT * from show_plan ORDER BY price DESC) b GROUP BY b.desp

和第一条执行的结果相同。。。

附带建表语句,看官可以自行进行测试


DROP TABLE IF EXISTS `show_plan`;
CREATE TABLE `show_plan` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `name` char(4) NOT NULL,
  `desp` int(11) NOT NULL,
  `price` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB ;


INSERT INTO `show_plan` VALUES ('1', 'a1', '1', '55');
INSERT INTO `show_plan` VALUES ('2', 'a2', '1', '20');
INSERT INTO `show_plan` VALUES ('3', 'a3', '1', '63');
INSERT INTO `show_plan` VALUES ('4', 'a4', '2', '89');
INSERT INTO `show_plan` VALUES ('5', 'a5', '2', '78');
INSERT INTO `show_plan` VALUES ('6', 'a6', '2', '90');
INSERT INTO `show_plan` VALUES ('7', 'a7', '3', '88');
INSERT INTO `show_plan` VALUES ('8', 'a8', '3', '77');
INSERT INTO `show_plan` VALUES ('9', 'a9', '3', '100');
INSERT INTO `show_plan` VALUES ('10', 'a10', '1', '77');
INSERT INTO `show_plan` VALUES ('11', 'a11', '4', '75');

“如何解决mysql  group by问题 ”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

推荐阅读:
  1. MySQL报错“only_full_group_by” 怎么解决
  2. mysql不支持group by的解决方法小结

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mysql

上一篇:intellij代码提示问题有哪些

下一篇:如何获取struts2的一些参数

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》