【问题标题】:Selecting rows with max value in a column选择列中具有最大值的行
【发布时间】:2021-07-23 09:25:32
【问题描述】:

我正在尝试选择 numTimesPurchasedTable 中在 numTimesPurchased 列上具有最大值的行

SELECT item, title, MAX(numTimesPurchased) 
FROM (SELECT Purchase.item, Item.title, SUM(quantity) AS numTimesPurchased 
FROM Item INNER JOIN Purchase ON Item.id = Purchase.item 
GROUP BY item, title) AS numTimesPurchasedTable;

numTimesPurchasedTable 看起来像这样

item title numTimesPurchased
1    a     4
2    b     7
3    c     7

但是,我收到错误:“错误代码:1140。在没有 GROUP BY 的聚合查询中,SELECT 列表的表达式 #1 包含非聚合列 'numTimesPurchasedTable.item'”

有没有办法在一个查询中完成这项工作?

【问题讨论】:

    标签: mysql database select max


    【解决方案1】:

    如果你只需要最大的单行,那么使用LIMIT:

    SELECT Purchase.item, Item.title, SUM(quantity) AS numTimesPurchased 
    FROM Item INNER JOIN Purchase ON Item.id = Purchase.item 
    GROUP BY item, title
    ORDER BY numTimesPurchased DESC LIMIT 1;
    

    【讨论】:

    • 是否有解决方法让两行具有相同的最大值?我无法弄清楚那部分
    • 您使用的是 MySQL 8.0 吗?对于您所描述的情况,解决方案是使用window functions,这样您就可以获得排名为 1 而不是位置为 1 的行。
    猜你喜欢
    • 2018-12-16
    • 1970-01-01
    • 2021-08-16
    • 2018-10-06
    • 2011-02-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多