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 中对于设置STRICT_CHECKS ON

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

相关文章:

sql - 空间记录的迭代查询

sql - INSERTED 表中的多行

SQL Server - 有没有办法在没有备份的情况下恢复损坏的数据库?

sql - 如何在sql中选择2行的不同组合

sql - 创建不可为空的列,但使用某个给定值填充现有的 NULL

mysql - 在 SELECT 中使用键时如何从另一个表中获取名称?

mysql - 连接 MySQL 中重复值的引用

mysql - SQL 搜索配置

mysql - SQL:使用 IFF 根据用户选择的参数设置条件

sql-server - 根据列数据重新排列和删除 SQL 列的重复数据