小问题,大苦恼(not in 与 not exists)
两个表toparcel,tcgrade,内容如下
SQL> select GradeLevel from tcgrade;
GRAD
----
1
2
3
4
5
SQL> select gradelevel,count(*) from toparcel
2 where substr(LandUsecode,1,2)='11' group by gradelevel;
GRAD COUNT(*)
---- ----------
1 166
2 126
3 103
4 231
5 211
14
使用not in
SQL> select count(*) from toparcel a
2 where substr(LandUsecode,1,2)='11' and
3 (a.gradelevel not in (select GradeLevel from tcgrade));
COUNT(*)
----------
0
显然不对
SQL> select count(*) from toparcel a
2 where substr(LandUsecode,1,2)='11' and
3 not (a.gradelevel in (select GradeLevel from tcgrade));
COUNT(*)
----------
0
也不对
而这样是对
SQL> select count(*) from toparcel a
2 where substr(LandUsecode,1,2)='11' and not exists
3 (select GradeLevel from tcgrade b where b.gradelevel=a.gradelevel);
COUNT(*)
----------
14
我想知道,not in怎么写是正确的