SQL语句中exists/not exists的用法分析

摘自:http://blog.csdn.net/zengcong2013/article/details/45820639

今天用到exists,结果代码居然忘了怎么写了,这里分享下

1、Student:


Sno


Sname


Ssex


Sage


Sdept


200215121


李勇



20


CS


200215122


刘晨



19


CS


200215123


王敏



18


MA


200215124


张立



19


IS

2、Course:


Cno


Cname


Cpno


Ccredit


1


数据库


5


4


2


数学


2


3


信息系统


1


4


4


操作系统


6


3


5


数据结构


7


4


6


数据处理


2


7


PASCAL语言


6


4

3、SC:


Sno


Cno


Credit


200215121


1


92


200215121


2


85


200215121


3


88


200215122


2


90


200215122


3


80

例1:查询所有选修了1号课程的学生的姓名。

解法1:利用exists

首先取Student表中的一个元组,然后在SC表中依次找SC.Sno=该元组的Sno,并且对应的Cno=‘1‘,如果存在,则外层查询的where子句返回为真,则Student表中的该元组可以输出。然后依次遍历Student表中的其他元组。

举个例子:对于在学生表中学号等于2002151121这个元组,在SC表中第一条记录即符合条件,然后where 子句返回 true,所以该条元组可以输出。然后依次遍历。

select Sname

from  Student

where exists

(

select *

from SC

where Sno = Student.Sno AND Cno=‘1‘

);

解法2:利用连接查询

select Sname

from Student,SC

where Student.Sno=SC.Sno AND SC.Cno=‘1‘;

例2:查询没有选修1号课程的学生的姓名。

解:

select Sname

from Student

where not exists

(

select *

from SC

where Sno=Student.Sno  AND   Cno=‘1‘

);

例3:查询选修了全部课程的学生姓名。

select Sname

from Student

where not exists

(

select *

from Course

where not exists

(

select *

from  SC

where Sno=Student.Sno AND

Cno=Course.Cno

) );

查找语义:查询这样的学生,没有一门课程是他不选修的。

查找过程:

首先,选取Student表中的一个元组,然后在依次判断Course表中的每个元组是否可以输出,只要有一个课程可以输出,则最外层查询的where子句返回为false;而在判断某个课程是否可以输出时,则要利用第三层查询,利用当前的学号和当前的课程号,在SC表中查询,如果存在,则第二层查询where子句返回false。至此,每一门课程都不可以输出时,这个学号对应的元组才可以输出。表示这个学生选修了全部的课程。

例4:至少选修了学生200215122选修的全部课程的学生号码。

select distinct Sno

from SC SCX

where not exists

(

select *

from SC SCY

where SCY.Sno=‘2002151122‘  AND

not exists

(

select *

from SC SCZ

where SCZ.Sno=SCX.Sno  AND

SCZ.Cno=SCY.Cno));

查询语义:不存在这样的课程y,学生200215122选修了y,而学生x没选。

查询过程:先在SCX表中选一条记录,比方说第一条,然后再看SCY表中,只有SCY表中全部不能输出,第一层查询的where子句才返回true,第一条记录就可以输出;所以就要一次查看SCY表中的每一个元组,前三个,因为学号首先不满足=200215122所以必然不能输出,第四个的话,就要看其AND后面的not exists返回什么值,而这又取决于第三层查询中是否存在满足学号等于SCX.Sno且课程号=SCY.Cno的元组,经查看,有 ,则返回false,所以第四个也不能输出,第五个类似,所以,第一层查询的not exists返回true。所以第一条记录可以输出。

时间: 2024-08-24 02:27:40

SQL语句中exists/not exists的用法分析的相关文章

Sql语句中IN和exists的区别及应用

表展示 首先,查询中涉及到的两个表,一个user和一个order表,具体表的内容如下: user表: order表: in 确定给定的值是否与子查询或列表中的值相匹配.in在查询的时候,首先查询子查询的表,然后将内表和外表做一个笛卡尔积,然后按照条件进行筛选.所以相对内表比较小的时候,in的速度较快. 具体sql语句如下: 1 SELECT 2 * 3 FROM 4 `user` 5 WHERE 6 `user`.id IN ( 7 SELECT 8 `order`.user_id 9 FROM

Sql 语句中 IN 和 EXISTS 的区别及应用

演示demo表: student表 DROP TABLE IF EXISTS `student`; CREATE TABLE `student` ( `stuid` varchar(16) NOT NULL COMMENT '学号', `stunm` varchar(20) NOT NULL COMMENT '学生姓名', PRIMARY KEY (`stuid`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ------------------------

Sql语句中IN等方面的用法

select * from txt1 select * from txt2 select * from txt1 where name in (select name from txt2 where chk = 0) select * from txt1 where name not in (select name from txt2 where chk = 0) select * from txt1 inner join txt2 on txt1.name = txt2.name select

SQL点滴35—SQL语句中的exists

原文:SQL点滴35-SQL语句中的exists 比如在Northwind数据库中有一个查询为 SELECT c.CustomerId,CompanyName FROM Customers c WHERE EXISTS( SELECT OrderID FROM Orders o WHERE o.CustomerID=c.CustomerID) 这里面的EXISTS是如何运作呢?子查询返回的是OrderId字段,可是外面的查询要找的是CustomerID和CompanyName字段,这两个字段肯定

SQL语句中having的用法

在 SQL 中增加 HAVING 子句原因是,WHERE 关键字无法与合计函数一起使用. having子句用法一(来自w3school): SQL HAVING 语法如下 SELECT column_name, aggregate_function(column_name) FROM table_name WHERE column_name operator value GROUP BY column_name HAVING aggregate_function(column_name) ope

SQL语句中count(1)count(*)count(字段)用法的区别

SQL语句中count(1)count(*)count(字段)用法的区别 在SQL语句中count函数是最常用的函数之一,count函数是用来统计表中记录数的一个函数, 一. count(1)和count(*)的区别 1. count(1)和count(*)的作用: 都是检索表中所有记录行的数目,不论其是否包含null值. 2. 区别:但是count(1)比count(*)效率更高 二 . count(字段)与count(1)和count(*)的区别 count(字段)的作用是检索表中的这个字段

SQL语句中的select高级用法

为了更好的了解下面的知识点,我们先创建两张表并插入数据. # 学生表 +----+-----------+------+--------+--------+--------+-----------+ | id | name | age | height | gender | cls_id | is_delete | +----+-----------+------+--------+--------+--------+-----------+ | 1 | 小明 | 18 | 180.00 | 女

select 1 from ... sql语句中的1解读

摘自:http://blog.csdn.net/zengcong2013/article/details/48224509 select  1 from ..., sql语句中的1代表什么意思?查出来是个什么结果?         select 1 from table;与select anycol(目的表集合中的任意一行) from table;与select * from table 从作用上来说是没有差别的,都是查看是否有记录,一般是作条件查询用的.select 1 from 中的1是一常

SQL语句中,Conversion failed when converting datetime from character string.错误的解决办法

在项目开发过程中,我们经常要做一些以时间为条件的查询,比如查询指定时间范围内的历史记录,然而这些时间都是从UI传递过来的参数,所以我们写的sql语句就必须用到字符串拼接.当然,在C#中写SQL语句还好处理,可以使用C#的字符串函数做对应的数据类型转换.但是,如果用的是存储过程的话,就有点纠结了.下面来说一下我在写存储过程中遇到的问题: 为了更加直接的说明问题,写如下一个简单的例子: declare @dateFrom datetime; declare @dateTo datetime; dec

回顾sql语句中的各种连接

1. 内连接(Inner Join) 内连接是最常见的一种连接,它页被称为普通连接,而E.FCodd最早称之为自然连接. 下面是ANSI SQL-92标准 select * from    t_institution i inner join t_teller t on i.inst_no = t.inst_no where i.inst_no = "5801" 其中inner可以省略. 等价于早期的连接语法 select * from t_institution i, t_telle