我制作了一个sqlfiddle,其中列出了 4 种不同的方法来实现你想要的。请注意,我在您的示例中添加了另一行。所以你有两行最大日期。看到查询之间的区别了吗?尽管有 2 行符合条件,但 Manoj 的方式只会给您一行。您可以单击“查看执行计划”以查看 SQL Server 处理这些查询的不同之处。
4 种不同的方式(用标准 SQL 编写,它们应该适用于每个 RDBMS):
select A
from TAB
where
B = (select max(B) from TAB);
select top 1 * from tab order by b desc;
select
*
from
tab t1
left join tab t2 on t1.b < t2.b
where t2.b is null;
select
*
from
tab t1
inner join (
select max(b) as b from tab
) t2 on t1.b = t2.b;
多亏了 a_horse_with_no_name,这里还有另外两种方法,特别是对于 SQL Server:
select *
from (
select a,
b,
rank() over (order by b desc) as rnk
from tab
) t
where rnk = 1;
select *
from (
select a,
b,
max(b) over () as max_b
from tab
) t
where b = max_b;
看到他们在这里工作。