首页 > 数据库 > mysql教程 > 如何从数据库表中检索前 n 个最大值?

如何从数据库表中检索前 n 个最大值?

Barbara Streisand
发布: 2024-11-10 10:59:02
原创
692 人浏览过

How to Retrieve the Top n Max Values from a Database Table?

从表中选择最高的最大值

在数据库管理中,可能需要从表中检索前 n 个最高值。为了实现这一目标,有几种方法可用。考虑下表:

column1  column2
   1       foo
   2       foo
   3       foo
   4       foo
   5       bar
   6       bar
   7       bar
   8       bar
登录后复制

对于 n=2,我们希望获得以下结果:

3    
4    
7    
8    
登录后复制

使用 Group Max 进行近似

最初的方法是计算每个组的最大值:

SELECT max(column1) FROM table GROUP BY column2
登录后复制

但是,此方法仅提供每个组的最高值,而不是前 n 个值。

基于联合的解决方案

对于 n=2,可以使用以下基于联合的查询:

SELECT max(column1) m
FROM table t
GROUP BY column2
UNION
SELECT max(column1) m
FROM table t
WHERE column1 NOT IN (SELECT max(column1)
                      WHERE column2 = t.column2)
登录后复制

此查询选择顶部值,然后通过连接排除重复项第二个查询,查找尚未选择的下一个最高值。

排名模拟

对于任何 n 值,更通用的方法是模拟排名( ) 分区上的函数。一种方法是:

SELECT t.*
FROM
   (SELECT grouper,
          (SELECT val
           FROM table li
           WHERE li.grouper = dlo.grouper
           ORDER BY
                 li.grouper, li.val DESC
           LIMIT 2,1) AS mid
   FROM
      (
      SELECT DISTINCT grouper
      FROM table
      ) dlo
   ) lo, table t
WHERE t.grouper = lo.grouper
      AND t.val > lo.mid
登录后复制

此查询按所需列对值进行分组,然后在指定限制内​​查找每个组的下一个最高值(在本例中,n= 2,1) 2).

通过遵循这些方法,您可以有效地从给定表中选择前 n 个最大值,确保消除重复值并返回正确的记录数。

以上是如何从数据库表中检索前 n 个最大值?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板