sql server 2008管理工作室没有检查我的查询的语法
发布时间:2020-05-23 15:22:52 所属栏目:MsSql 来源:互联网
导读:一如以往,会有一个合理的解释我的惊喜,但直到那时…. 我有这个查询 delete from Photo where hs_id in (select hs_id from HotelSupplier where id = 142) 它执行得很好(后来我发现整个照片表都是空的) 但奇怪的是:在HotelSupplier中没有字段hs_id,它被称为h
|
一如以往,会有一个合理的解释我的惊喜,但直到那时…. 我有这个查询 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 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- sql-server – ORM for Node JS,如.net Entity F
- foreign-keys – 用于在数据库中发现事实上的外键
- 数据库无法将django app部署到amazon beanstalk
- 数据库 – OrbitDB,Gun,HyperDrive和BigchainDB如
- 在SQL Server中加入CSV列
- asp.net实现将Excel中多个sheet数据导入到SQLSER
- 理解SQL SERVER中的逻辑读,预读和物理读用法示例
- sql-server – 这是MERGE中的错误,是否正确执行F
- 数据库 – 版本跟踪,使用django自动执行数据库模
- sql – 如何检查默认值约束是否存在?
热点阅读
