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);

浙公网安备 33010602011771号