SQL Server 子查询隐式限定

SQL Server有两张表,TestTableA 和TestTableB,表结构分别如下:

那么想一下执行下面SQL的结果是什么呢?

select * from TestTableA where tid in (select tdesc from TestTableB)

看一下子查询 select tdesc from TestTableB根据上面的表结构我们不难发现,TestTableB其实是没有tdesc字段的。但是实际上这样执行并不会报错,看下执行结果:

那么为什么能查出结果而且不报错呢,我们先看一下执行计划

可以看到,其实他实际上执行的是TestTableA.tid=TestTableA.tdesc

最终我找到了SQL Server的官方说明文档:

子查询 (SQL Server) - SQL Server | Microsoft Learn

这里做了特别说明,也就是说如果子查询的TestTableB没有tdesc字段,但是外部查询TestTableA存在tdesc字段,SQL Server就会触发隐式限定,将子查询的TestTableB用TestTableA替换掉。

所以SQL执行分析器最终执行的SQL是:

select * from TestTableA where tid in (select tdesc from TestTableA);

 

posted @   新*  阅读(39)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异

喜欢请打赏

扫描二维码打赏

支付宝打赏

点击右上角即可分享
微信分享提示