我们知道,SQL 是基于集合理论的。
首先说一下union 和union all
UNION 将返回两个查询的结果并去除其中的重复部份,UNION ALL 与UNION 一样对表进行了合并但是它不去掉重复的记录。
SQL> SELECT NAME FROM SOFTBALL UNION ALL SELECT NAME FROM FOOTBALL;
用法及:将两个select语句合并即可。
可以看到UNION ALL 与UNION 一样对表进行了合并但是它不去掉重复的记录可是如果我们想知道都有谁同时在两个表中呢UNION 无法做到这一点我们需要学习使用INTERSECT ,INTERSECT 相交。
INTERSECT 返回两个表中共有的行
实例:
SQL> SELECT * FROM FOOTBALL INTERSECT SELECT * FROM SOFTBALL;
MINUS 相减
MINUS 返回的记录是存在于第一个表中但不存在于第二个表中的记录
SELECT * FROM FOOTBALL MINUS SELECT * FROM SOFTBALL;例如这个语句返回的数据只在第一个表中而不在第二个表中的数据。
从属运算IN and BETWEEN
这两个运算符对你已经做过的例子提供了更快捷的操
in:
SELECT * FROM FRIENDS WHERE STATE IN('CA','CO','LA')等价于SELECT * FROM FRIENDS WHERE STATE= 'CA' OR STATE ='CO' OR STATE ='LA'
between:查找符合某一范围的记录
SELECT * FROM PRICE WHERE WHOLESALE> 0.25 AND WHOLESALE<0.75 等价于:
SELECT * FROM PRICE WHERE WHOLESALE BETWEEN 0.25 AND 0.75
本文详细介绍了SQL中的集合操作包括UNION、UNION ALL、INTERSECT和MINUS,并通过实例展示了如何使用这些操作来合并、查找交集和差集等。此外还介绍了IN和BETWEEN运算符的用法。
720

被折叠的 条评论
为什么被折叠?



