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_id
HotelSupplier 没有任何领域,它被称为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(并且子查询返回至少一行),此查询的结果将是删除Photo
where中的所有行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
归档时间: |
|
查看次数: |
1161 次 |
最近记录: |