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);
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异