我有以下查询:
SELECT 1,
row_number() over (partition by lower(X), lower(Y) order by X DESC) AS rn
FROM dbo.MyTable
WHERE rn = 1
当我运行它时,我会得到一个错误Invalid column name 'rn'.
。
我不明白为什么要这样做,因为rn
是在SELECT
部分中定义的。
我也尝试过用WHERE
替换HAVING
。
发布于 2016-12-19 09:51:55
WHERE
在窗口函数之前运行。所以在一个派生表中运行整个程序。
SELECT t.*
FROM (
SELECT 1,
row_number() over (
partition by lower(X), lower(Y) order by X DESC
) AS rn
FROM dbo.MyTable
) AS t
WHERE rn = 1;
https://dba.stackexchange.com/questions/158595
复制相似问题