当前位置: 首页 > 面试题库 >

MySQL Group By,每种类型的前N个

盖诚
2023-03-14
问题内容

我有一张这样的桌子:

等级信
1个
2个
3个
4个
5℃
6个
7℃
8℃
9号
10摄氏度

我需要按升序排列每个字母的前2个:

等级信
1个
2个
3个
5℃
7℃
9号

我该怎么办?使用GROUP BY获得前1名非常简单,但是我似乎无法让它适用于多个条目


问题答案:
select distinct rank, letter
  from table1 t2
 where rank in 
         (select top 2 rank
            from table1 t2 
           where t2.letter = t1.letter 
           order by rank)
       order by letter, rank

编辑:(我的第一次尝试将无法在MySql(Quassnoi注释)上工作,例如,我将其修改为可在sql服务器上工作)

第二次尝试:

select t.letter, t.rank
from table1 t
join (
    select t1.letter, min(t1.rank) m
    from table1 t1
    join (select t0.letter, min(t0.rank) m, count(1) c 
           from table1 t0 group by t0.letter) t2
    on t1.letter = t2.letter and ((t2.c = 1) or (t2.c > 1 and t1.rank > m))
    group by t1.letter) t3 
  on t.letter = t3.letter and t.rank <= t3.m


 类似资料:
  • 如何创建任何类型的类对象(字符串、char、int、浮动、双。短、长、字节、...),以便我可以使用接受类对象的所有类型的链接列表

  • 问题内容: 我对伪类以及伪类的工作方式感到困惑,尤其是与类相比。 也许我有一个错误的想法,但是考虑到这种结构 ..第三个子元素(第一个带有类标签的元素)应该(也许?)可用 但是,至少在这里是chrome,它不会选择它。仅当它是该行中的第一个孩子时,它才似乎起作用。这与-因此,this和?之间有什么区别? 问题答案: 该伪类指的是“第N个匹配的子元素”,如果你有一个结构如下含义: 然后将选择第二个也

  • 问题内容: 我已阅读这篇文章:http : //www.xaprb.com/blog/2006/12/07/how- to-select-the-firstleastmax-row-per-group-in- sql/ 并搜索其他问题 我有一个像这样的表: 我正在尝试获取按user.id分组的table.id的计数,如果user.id的计数大于7,则仅将结果显示为7(也就是将计数结果限制为7)。

  • 假设我有一个名为的Kafka主题,它有几个消息类型(每个消息类型都有不同的Avro模式),如、等等。我想了解一下用Spring Cloud Stream发布/接收相同主题的不同类型是否可行(而且有意义)。特别是,拥有几个将非常有用,每个专用于特定类型。根据这篇博文,当需要订购消息时,这是非常有用的,因为它们与同一个实体相关。这种情况下的配置示例是什么?

  • 本节要讨论的是当给定 n(n>=0)个结点时,可以构建多少种形态不同的树。 如果两棵树中各个结点的位置都一一对应,可以说这两棵树相似。如果两棵树不仅相似,而且对应结点上的数据也相同,就可以说这两棵树等价。本节中,形态不同的树指的是互不相似的树。 前面介绍过,对于任意一棵普通树,通过孩子兄弟表示法的转化,都可以找到唯一的一棵 二叉树与之对应。所以本节研究的题目也可以转化成:n 个结点可以构建多少种形

  • 问题内容: 我正在尝试使用By.cssSelector来捕获类c3的第n个dom元素,其结构如下: 测试我的CSS选择器时,我变得越来越困惑。此选择器正确选择c2 / c3的第二个实例: 而: 什么都不选。 更糟糕的是,将其转换为硒,我似乎始终没有为所有3个版本找到任何东西。有很多选择这些元素的替代方法(我可能只做XPATH),但是我对nth-of- type的缺乏了解使我发疯。谁能提供关于第二个