作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设我正在尝试对银行和分行进行分类,其中一家银行通过 branches.bank_id
拥有多个分行。每个分支都有一个令人敬畏的因素 branches.awesomeness
。
我将如何构造一个查询,以返回按最差分行排序的银行列表?
我有以下内容:
SELECT * FROM `banks`
INNER JOIN `branches` ON `branches`.`bank_id` = `banks`.`id`
GROUP BY `banks`.`id`
ORDER BY `branches`.`awesomeness` ASC;
当我尝试此操作时,其信息与任何给定银行分组的分支机构并不是最差的分支机构(这是在删除 GROUP BY
语句的结果中最早出现的分支机构) .
我该如何完成?
这是为了与 Rails 一起使用,所以如果使用 arel 风格的语法更方便或考虑到 Rails 特定的要求,请随意将它们放入。
最佳答案
如果你还想获取分支数据,我不明白你为什么要使用GROUP BY
。从查询中删除 GROUP BY
,并将排序更新为:ORDER BY branches.bank_id, branches.awesomeness
如果您坚持分组,请使用 MIN()
聚合函数来为每个组获取最少的性能。
ORDER BY MIN(branches.awesomeness) ASC;
更新:如果您想要两者的混合,并希望按“最不令人敬畏”对银行进行排序,并根据自己的敬畏程度对银行中的分支机构进行排序,请使用此查询:
SELECT b.*, r.*, brs.MinAw
FROM banks b
INNER JOIN branches r ON r.bank_id = b.id
INNER JOIN (
SELECT bank_id, MIN(awesomeness) MinAw
FROM branches
GROUP BY bank_id
) brs ON b.id = brs.bank_id
ORDER BY brs.MinAw, r.awesomeness;
关于sql - 如何让 GROUP BY 选择 "earliest"结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4911613/
我是一名优秀的程序员,十分优秀!