如果我们想查询出一个对象包含的集合中每个对象都满足某一特定条件,有点绕,比如说 一个学生可以有N本书,那么我们想找出 所有的书都是新书(new=true)的学生。那么一般我们可以使用下面的语句。
Select t from Student t left join t.books b where true=all( select b.new from b where b.student = t )
可是上面的语句真的正确吗,不是, 因为 有一种特殊情况,比如有个学生没有书,然而如果我们执行这个语句,这个没有书的学生还是会被查询进来的(因为Null的原因估计) ,那么我们就要修改上面的语句为
Select t from Student t left join t.books b where
exists ( select b.new from b where b.student = t )
and true=all( select b.new from b where b.student = t )
限定了只有有书的学生,这样我们查询出的结果就不会有错了
本文探讨了在查询含有集合的对象时如何确保所有子项均符合特定条件的方法,并修正了一种常见错误写法,避免因NULL值导致的误判。
282

被折叠的 条评论
为什么被折叠?



