sql server 2008 management studio 不检查我的查询语法

标签 sql sql-server sql-server-2008 ssms

一如既往,我的惊讶会有一个合理的解释,但在那之前......

我有这个问题

delete from Photo  where hs_id  in (select hs_id  from HotelSupplier where id = 142)

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

但奇怪的是:HotelSupplier中没有字段hs_id,它叫做hs_key!

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

select hs_id  from HotelSupplier where id = 142

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

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

最佳答案

它从外部查询中获取 hs_id 的值。

如果查询不在其 select 列表中投影所选表的任何列,这是完全有效的。

例如

select 10 from HotelSupplier where id = 142

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

非限定列引用从最近的范围向外解析,因此这仅被视为相关子查询。

只要 HotelSupplier 至少有一行 id = 142(并且所以子查询至少返回一行)

如果你考虑一下这个效果是什么,可能会更清楚一些

delete from Photo  where Photo.hs_id  in (select Photo.hs_id)

这当然等同于

delete from Photo where Photo.hs_id = Photo.hs_id

顺便说一下,这是我个人在 Microsoft Connect 上错误报告的最常见的“错误”。 Erland Sommarskog 将其包含在他的 wishlist 中对于 SET STRICT_CHECKS ON

关于sql server 2008 management studio 不检查我的查询语法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31201842/

相关文章:

performance - 唯一记录的总和 - 比游标更好的性能

sql - mysql中的复杂查询

sql - 如何删除gorm包的Create方法中的RETURNING子句?

sql - 在 Postgresql 中选择正聚合值并忽略负值

asp.net - 事务的 SQL 错误超时

mysql - 在 SQL 连接语句中添加 case 语句

java - 选择某一行SQL

sql-server - 如何在sql server中将列转置为行

sql-server - Entity Framework ,如何增加限制?

SQL使用while循环计算多个元素的值