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

前端之家收集整理的这篇文章主要介绍了sql server 2008管理工作室没有检查我的查询的语法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
一如以往,会有一个合理的解释我的惊喜,但直到那时….

我有这个查询

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的值.

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

查询的结果将是从Photos中删除所有行,其中hs_id不为null,只要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

原文链接:https://www.f2er.com/mssql/76079.html

猜你在找的MsSQL相关文章