就是不在这个范围的意思
select id
from table
where name not exists(select 1
from table
where name = 'aaa')
也许你看不懂这个1的意思,不过在使用EXISTS的时候,通常都会使用1,它代表所查询出来的集合,等同于select name。
整个例子的意思是:查询name不等于aaa的所有ID。
不明白再问我,谢谢!
select from student a where exists ( select 1 from student b where bname='张三'and bcollege=acollege)
在sql语言里"存在"exists子句是非常不好理解的。
exists子句有两种用法,一种为独立exists子查询,另一种是父子关联子查询。前者对父查询不构成筛选作用,子查询若果有记录存在的话则输出所有的父查询记录集,反之则父查询输出空记录集。后者会对父查询构成筛选作用,不使用not关键字的情况下输出父查询中与子查询的交集,而使用not时则输出父查询中与子查询的非交集。至于如何判断exists子查询属于独立还是父子关联查询,以及为什么父子关联exists子查询会对父查询构成筛选作用,解释起来需要很大的篇幅这里就不讲了。反正我们记住父子关联查询的最常用功能就是它可以求出两张表的交集或非交集(使用not关键字)和不使用group分组的情况下求出某张表的最大值或最小值。
现在回到题主的具体问题上,这个问题涉及到三张表,学生表student、选课表sc、课程表course。
提问要求列出选取了所有课程的学生名单。
下面是提问中给出的sql语句:
select sname from student
where not exists(
select from course
where not exists(
select from sc
where sno=studentsno
and cno=coursecno));
从该语句我们看到它使用了两个嵌套父子关联不存在判断not exists子句,显然是要通过求非交集的方法查出选修了所有课程的学生名单。
一个学生如果他至少有一门课程没有选修,那么他在课程表里就会存在与选课表的非交集,我们姑且称之为“未选所有课程学生名单子集”,它由内层的not exists选出
select from course
where not exists(
select from sc
sno=studentsno
and cno=coursecno)
这个内层父子关联存在子查询选出课程表里与选课表的非交集,最内层选课表sc的课程号cno、学号sno分别与第二层父表course课程的cno、最外层父表studen学生表的sno进行对等连接,不存在对等的记录即为非交集,从而筛选出“未选所有课程学生名单子集”。
未完待续
in和exist的主要区别体现在对sql执行计划的影响上。
传统上认为,如果子查询的条件更具选择性(selective),就用in;而如果父查询(外层查询)的条件更具选择性(selective),就用exist。
具体的内容可以参考以下oracle原厂的手册,不好意思,oracle的原厂手册都是英文版的。
对于你举的那个例子,用in和用or是一样的,因为它们的执行计划肯定是一样的。
另外需要特别注意的是,in和exist的区别只在10203及以前的版本中存在;而10204及以后的版本中,in和exist的效果是完全一样的,手册中也删除了有关二者区别的说明。
以下是对手册的引用:
In certain circumstances, it is better to use IN rather than EXISTS In general, if the selective predicate is in the subquery, then use IN If the selective predicate is in the parent query, then use EXISTS
Sometimes, Oracle can rewrite a subquery when used with an IN clause to take advantage of selectivity specified in the subquery This is most beneficial when the most selective filter appears in the subquery and there are indexes on the join columns Conversely, using EXISTS is beneficial when the most selective filter is in the parent query This allows the selective predicates in the parent query to be applied before filtering the rows against the EXISTS criteria
补充:
看sql语句看执行计划就可以了,没必要比较某次的时间长短,因为语句执行时间长短跟很多其他因素有关,比如数据是否在buffer cache中(第二次执行一般会比第一次快不少)、数据库负载不同等。对于常量,in的效果完全等同于or,这是毫无疑问的。
以上就是关于数据库语言 not exists 是什么意思全部的内容,包括:数据库语言 not exists 是什么意思、数据库中select语句的存在量词exists怎么使用、MySQL数据库代码中,两个exists语句同时出现同一查询语句中时,怎么理解,,越详细越好。,等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)