sql server 2008管理工作室没有检查我的查询的语法

Mic*_*hel 13 sql sql-server ssms sql-server-2008

一如往常,我会有一个合理的解释,但直到那时......

我有这个问题

delete from Photo  where hs_id  in (select hs_id  from HotelSupplier where id = 142)
Run Code Online (Sandbox Code Playgroud)

执行得很好(后来我发现整个照片表都是空的)

但奇怪的是:hs_idHotelSupplier 没有任何领域,它被称为hs_key!

所以当我执行最后一部分时

select hs_id  from HotelSupplier where id = 142
Run Code Online (Sandbox Code Playgroud)

单独(用鼠标选择那部分查询并点击F5),我得到一个错误,但是当我在in子句中使用它时,它不会!

我想知道这是否属于正常行为?

Mar*_*ith 24

hs_id 从外部查询中获取值.

拥有一个不会从select列表中的选定表中投影任何列的查询是完全有效的.

例如

select 10 from HotelSupplier where id = 142
Run Code Online (Sandbox Code Playgroud)

将返回一个结果集,其中包含与where子句匹配的行数和10所有行的值.

不合格的列引用从最近的范围向外解析,因此这被视为相关的子查询.

只要HotelSupplier至少有一行id = 142(并且子查询返回至少一行),此查询的结果将是删除Photowhere中的所有行hs_id不为null

如果考虑一下它的影响,可能会更清楚一些

delete from Photo  where Photo.hs_id  in (select Photo.hs_id)
Run Code Online (Sandbox Code Playgroud)

这当然等同于

delete from Photo where Photo.hs_id = Photo.hs_id
Run Code Online (Sandbox Code Playgroud)

顺便说一句,这是我个人在Microsoft Connect上错误报告的最常见的"bug".厄兰Sommarskog包括在他的心愿SET STRICT_CHECKS ON

  • +1 - 只是想在您的示例中明确指出一个好的做法 - 包括整个查询中每个列的表名(两个部分标识符).一般的好习惯,删除陈述中的宝贵做法! (6认同)
  • @Michel - 这不是不存在的.它被视为相关的子查询,并使用从外部查询传入的值为每一行进行评估. (2认同)