在 Oracle 中选择第二大的最小值

Select second most minimum value in Oracle(在 Oracle 中选择第二大的最小值)
本文介绍了在 Oracle 中选择第二大的最小值的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要编写一个查询,从整数列表中选择一个最小值和第二个最小值.

I need to write a query that selects a minimum value and it's second most minimum value from a list of integers.

抓取最小值很明显:

select min(value) from table;

但是第二小的就没有那么明显了.

But the second smallest is not so obvious.

为了记录,这个整数列表不是连续的——最小值可以是 1000,第二大的最小值可以是 10000.

For the record, this list of integers is not sequential -- the min can be 1000, and the second most min can be 10000.

推荐答案

使用解析函数

SELECT value
  FROM (SELECT value,
               dense_rank() over (order by value asc) rnk
          FROM table)
 WHERE rnk = 2

分析函数RANKDENSE_RANKROW_NUMBER 除了处理关系的方式外是相同的.RANK 使用运动风格的打破平局的过程,所以如果两行平局为 1,下一行的排名为 3.DENSE_RANK 给出两行并列第一的排名为 1,然后分配下一行的排名为 2.ROW_NUMBER 任意打破平局,并给予具有最低值的两行之一排名 1,另一行排名 2.

The analytic functions RANK, DENSE_RANK, and ROW_NUMBER are identical except for how they handle ties. RANK uses a sports-style process of breaking ties so if two rows tie for a rank of 1, the next row has a rank of 3. DENSE_RANK gives both of the rows tied for first place a rank of 1 and then assigns the next row a rank of 2. ROW_NUMBER arbitrarily breaks the tie and gives one of the two rows with the lowest value a rank of 1 and the other a rank of 2.

这篇关于在 Oracle 中选择第二大的最小值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)