MySql集合查询

WBOY
WBOYoriginal
2016-06-07 15:02:104076parcourir

SELECT语句的查询结果是元组的集合,所以多个SELECT语句的结果可进行集合操作。 集合操作主要包括并操作UNION、交操作INTERSECT、差操作EXCEPT。 注意, 参加集合操作的各查询结果的列数必须相同;对应的数据类型也必须相同。 本示例中的数据表有student,sc

SELECT语句的查询结果是元组的集合,所以多个SELECT语句的结果可进行集合操作。

集合操作主要包括并操作UNION、交操作INTERSECT、差操作EXCEPT。

注意,参加集合操作的各查询结果的列数必须相同;对应的数据类型也必须相同。

本示例中的数据表有student,sc,course三个,数据表的具体内容请看:Mysql数据库中的EXISTS和NOT EXISTS

UNION示例:

例子1.1

题目:查询计算机科学系的学生及年龄不大于19岁的学生。

SQL语句:

SELECT * FROM Student WHERE Sdept='CS' UNION 
SELECT * FROM Student WHERE Sage
查询结果:

<p><img  src="pic/20151007/551n4521ohp.png" alt="MySql集合查询" ></p>
<p>本查询实际上是求计算机系的所有学生与年龄不大于19岁的学生的并集。</p>
<p>与它等效的SQL语句是:</p>

<pre class="brush:php;toolbar:false">SELECT * FROM Student WHERE Sdept='CS' OR Sage

<p>注意:虽然这个两个SQL语句是等效的,但是本质上是不一样的,第一个SQL语句是分别进行两次SELECT然后将结果取并集;第二个SQL语句是直接进行了一次SELECT语句查询。</p>
<h2>INTERSECT示例:</h2>
<p>MySql语句并不至此INTERSECT,所以只能使用其替代语句<br>
</p>
<p>例子2.1</p>
<p>题目:查询计算机科学系中年龄不大于19岁的学生。</p>
<p>对应的SQL语句应该是:<br>
</p>
<pre class="brush:php;toolbar:false">SELECT * FROM Student 
WHERE Sdept='CS'
INTERSECT
SELECT * FROM Student
WHERE Sage
<br>
替代的SQL语句:

<pre class="brush:php;toolbar:false">SELECT *
FROM student
WHERE Sdept = 'CS'
AND Sage 
<p>查询结果:</p>
<p><img  src="pic/20151007/szhz2dupb40.png" alt="MySql集合查询" ></p>
<p>例子2.2</p>
<p>题目:查询即选修了课程1又选修了课程2的学生。(就是查询选修课程1的学生集合与选修课程2的学生集合的交集)</p>
<p>对应的SQL语句应该是:</p>

<pre class="brush:php;toolbar:false">SELECT Sno FROM SC
WHERE  Cno='1'
INTERSECT
SELECT Sno FROM SC
WHERE Cno='2';

替代的SQL语句为:

(使用IN)

SELECT Sno
FROM SC
WHERE Cno = '1'
AND Sno
IN (
SELECT Sno
FROM SC
WHERE Cno = '2'
)

或者为:

(使用EXISTS)

SELECT Sno
FROM SC SCX
WHERE Cno = '1'
AND EXISTS (
SELECT Sno
FROM SC SCY
WHERE Cno = '2'
AND SCX.Sno = SCY.Sno
)
查询结果为:

MySql集合查询

或者为:

(使用JOIN ON)

SELECT *
FROM SC SCX
JOIN SC SCY ON ( SCX.Cno = '1'
AND SCY.Cno = '2'
AND SCX.Sno = SCY.Sno )

MySql集合查询

EXCEPT操作:

很不幸,MySql也不支持EXCEPT操作,只能使用替代的语句。

例子3.1

查询计算机科学系的学生与年龄不大于19岁的学生的差集。

对应的SQL语句为:

SELECT * FROM Student WHERE Sdept='CS'
EXCEPT 
SELECT * FROM Student WHERE Sage
<br>
也就是查询计算机科学系中年龄大于19岁的学生。

<p>替换语句为:</p>
<p>(直接使用WHERE,不得不说这么做很简单,但是意思上不是很好理解)<br>
</p>

<pre class="brush:php;toolbar:false">SELECT *
FROM Student
WHERE Sdept = 'CS'
AND Sage >19

查询结果为:

MySql集合查询

或者替换语句为:

(使用NOT IN)

SELECT *
FROM Student
WHERE Sdept = 'CS'
AND Sno NOT
IN (
SELECT Sno
FROM Student
WHERE Sage 
查询结果为:<br>

<p><img  src="pic/20151007/5n02tssrxm0.png" alt="MySql集合查询" ></p>
或者使用替换语句为:
<p>(使用NOT EXISTS)</p>

<pre class="brush:php;toolbar:false">SELECT *
FROM Student SX
WHERE Sdept = 'CS'
AND NOT
EXISTS (
SELECT *
FROM Student SY
WHERE SY.Sage 
查询结果为:<br>

<p><img  src="pic/20151007/5n02tssrxm0.png" alt="MySql集合查询" ></p>
<h2>对集合操作结果的排序</h2>
<p>ORDER BY子句只能用于对最终查询结果排序,不能对中间结果排序。</p>
<p>任何情况下,ORDER BY子句只能出现在最后;对集合操作结果排序时,ORDER BY子句中用数字指定排序属性。</p>
<p>下面是一种<span>错误的写法</span>:</p>

<pre class="brush:php;toolbar:false">SELECT * FROM Student
WHERE Sdept='CS'
ORDER BY Sno
UNION
SELECT * FROM Student
WHERE Sage
<br>
正确的应该是:


<pre class="brush:php;toolbar:false">SELECT * FROM Student
WHERE Sdept='CS'
UNION
SELECT * FROM Student
WHERE Sage
输出结果:

<p><img  src="pic/20151007/q51xzjoghyr.png" alt="MySql集合查询" ></p>
<p>如果写成:</p>

<pre class="brush:php;toolbar:false">SELECT * FROM Student
WHERE Sdept='CS'
UNION
SELECT * FROM Student
WHERE Sage
输出结果为:

<p><img  src="pic/20151007/eyevak1hckc.png" alt="MySql集合查询" ><br>
</p>
<p><br>
</p>


Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn