gpt4 book ai didi

sql - 使用列的最大值从oracle sql表中过滤行

转载 作者:行者123 更新时间:2023-12-02 15:33:22 25 4
gpt4 key购买 nike

我正在学习 oracle SQL,我有一个如下表:

+--------+--------+------------------------+
| name | nation | count |
+--------+--------+------------------------+
| Ruben | UK | 2 |
| Ruben | EEUU | 16 |
| Cesar | UK | 21 |
| Cesar | EEUU | 12 |
| Cesar | FRANCE | 4 |
| John | FRANCE | 3 |
| John | UK | 7 |
| .... | .. | .. |
+--------+--------+------------------------+

上表表示我使用查询创建的内联 View 。如您所见,该表按名称和国家分组并进行一些计数。我想使用 count 列过滤表格,使其具有如下内容:

+--------+--------+
| name | nation |
+--------+--------+
| Ruben | EEUU |
| Cesar | UK |
| John | UK |
| .... | .. |
+--------+--------+

如您所见,我想为每个名称选择基于计数的国家。

最佳答案

使用keep解析关键字:

select name, min(nation) keep (dense_rank last order by cnt)
from (select name, nation, count(*) as cnt
from /* your data source */
group by name, nation)
group by name
  1. min(nation) - min 在这种情况下没有意义,但您必须保留它(没有就不行)
  2. keep - 只保留 nation
  3. 的一个结果
  4. dense_rank last 表示取最后一个元素
  5. order by cnt说的是如何定义元素的顺序

最终,每个名字都会成为计数最多的国家。可以用

实现相同的结果
select name, min(nation) keep (dense_rank first order by cnt desc)

关于sql - 使用列的最大值从oracle sql表中过滤行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22201274/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com