Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >用于SELECT和OVER的无效列

用于SELECT和OVER的无效列
EN

Database Administration用户
提问于 2016-12-19 09:49:52
回答 1查看 922关注 0票数 0

我有以下查询:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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

EN

回答 1

Database Administration用户

回答已采纳

发布于 2016-12-19 09:51:55

WHERE在窗口函数之前运行。所以在一个派生表中运行整个程序。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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;
票数 4
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/158595

复制
相关文章

相似问题

重写子select作为用“over(分区.)”生成的列的条件

40

无效语法和无效列

10

为SELECT分析和绑定变量。其中列IN ( ..。)查询

10

基于select的取消枢轴列

10

解释OVER子句

20
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文