先解释一下什么是集合运算。
在数据库中,集合运算就是对满足同一规则的记录进行的加减等四则运算。
集合运算符包括:union(并集)、intersect(交集)、except(差集)。
集合运算符可以去除重复行。如果希望集合运算符保留重复行,就需要使用ALL选项。
※MySQL不支持intersect和except。Oracle中使用MINUS代替except
表的加减法(以行为单位)
一、加法——union
select a,b from T1 union select a,b from T2
注意事项:①作为运算对象的记录的列数、列的类型必须一致
②union会去除重复的记录。包含重复记录可以使用ALL
③order by子句只能在最后使用一次。
二、选取表中公共部分——intersect
语法和注意事项同union。
select a,b from T1 intersect select a,b from T2
三、记录的减法——except
语法同union。
except有一点要特别注意:减数和被减数的位置不同,得到的结果也不相同。
表的联结(以列为单位对表进行联结)
一、内连接——INNER JOIN
有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行。(所谓的链接表就是数据库在做查询形成的中间表)。
二、外连接——OUTER JOIN
外连不但返回符合连接和查询条件的数据行,还返回不符合条件的一些行。
外连接分三类:左外连接(LEFT OUTER JOIN)、右外连接(RIGHT OUTER JOIN)和全外连接(FULL OUTER JOIN)。
三者的共同点是都返回符合连接条件和查询条件(即:内连接)的数据行。不同点如下:
左外连接还返回左表中不符合连接条件单符合查询条件的数据行。
右外连接还返回右表中不符合连接条件单符合查询条件的数据行。
全外连接还返回左表中不符合连接条件单符合查询条件的数据行,并且还返回右表中不符合连接条件单符合查询条件的数据行。
全外连接实际是上左外连接和右外连接的数学合集(去掉重复),即“全外=左外 UNION 右外”。
说明:左表就是在“(LEFT OUTER JOIN)”关键字左边的表。右表当然就是右边的了。在三种类型的外连接中,OUTER 关键字是可省略的。
三、联合连接——UNION JOIN
这是一种很少见的连接方式。Oracle、MySQL均不支持,其作用是:找出全外连接和内连接之间差异的所有行。这在数据分析中排错中比较常用。也可以利用数据库的集合操作来实现此功能。
四、自然连接——NATURAL INNER JOIN
自然连接无需指定连接列,SQL会检查两个表中是否相同名称的列,且假设他们在连接条件中使用,并且在连接条件中仅包含一个连接列。不允许使用ON语句,不允许指定显示列,显示列只能用*表示(ORACLE环境下测试的)。对于每种连接类型(除了交叉连接外),均可指定NATURAL
注意事项:
ON后面的条件(ON条件)和WHERE条件的区别:
ON条件:是过滤两个链接表笛卡尔积形成中间表的约束条件。
WHERE条件:在有ON条件的SELECT语句中是过滤中间表的约束条件。在没有ON的单表查询中,是限制物理表或者中间查询结果返回记录的约束。
在两表或多表连接中是限制连接形成最终中间表的返回结果的约束。
推荐的做法是:
ON只进行连接操作,WHERE只过滤中间表的记录