第一次:select* from A_CLASS where c1!=c1
,第二次:select* from A_CLASS where c1!=c2
,
第三次:select* from A_CLASS where c1!=c1
,第四次:select* from A_CLASS where c1!=c2
,
第五次:select* from A_CLASS where c2!=c1
,第六次:select* from A_CLASS where c2!=c2
,
第七次:select* from A_CLASS where c3!=c1
,第八次:select* from A_CLASS where c3!=c2
但是=换成了!=;这次是第六次和第八次没有被执行,其余的全被执行,s.CLASS_ID涉及到(c1,c2,c3)并且语句都返回了true;
所以STUDENT表中CLASS_ID字段为(c1,c2,c3)的数据都会被查询出来;
附:exists与in比较
in的用法相信大家很好理解。
select * from table_name where col_name [not] in(子查询);
- 先运行子查询,生成结果集
- 再运行外查询时,判断col_name在不在子查询里,在的话则返回该行,不在则不返回。
- col_name的列数和子查询的列数要相对应
当外大子小时,即查询的内容很大时,判断次数少,in优于exist【子查询小用in】
当外小子大时,即查询内容很小时,代入次数少,exists优于in【子查询大用exists】
总结:
1.exists执行外循环后,会拿着外循环的值,去内层查询,如果查询到就直接返回true,并且终止本次循环,如果是false,则会一直执行,直至循环完成还为false,则本次内循环不符合条件;
2.内层的判断条件不要写!=;查询的结果会不尽人意;
到此这篇关于sql中exists基本用法的文章就介绍到这了,更多相关sql exists的用法内容请搜索
更多SQL内容来自木庄网络博客