7-1 表的加减法

集合运算

集合运算就是对满足同一规则的记录,进行的加减等四则运算。

1.1 表的加法——UNION

表之间进行并集运算。

语法:

SELECT 对应列1,对应列2……
FROM 表1
UNION
SELECT 对应列1,对应列2……
FROM 表2;

UNION等集合运算符,通常都会出去重复的记录。

重复的记录

如果对应列内容 完全相同,而其他列有所不同,那也算是重复的记录。也就是说,如果SELECT之后的结果,完全相同的两条记录,会删掉重复的一条。

注意1

作为运算对象的记录的列数以及内容和类型必须相同。

注意2

可以使用任何SELECT语句,但是ORDER BY子句只能在最后一次使用。

包含重复行的并集——ALL

与UNION相似,但是如果有重复的记录,不会进行删除。

选取公共部分,交集——INTERSECT

语法与UNION完全相同。

作用是选取相交,也就是交集部分。

如果希望保留重复行,使用INTERSECT ALL


记录的减法——EXCEPT

语法与UNION完全相同。

作用:集合A EXCEPT 集合B ,

集合A减去与集合B相交的部分。

在其他DBMS

在Oracle中,

用MINUS代替EXCEPT。


7-2 联结(以列为单位,对表进行联结)

联结运算,通俗地说就是把其他表的列添加过来。

内联结——INNER JOIN

例:

SELECT T.name , T.age , T.id , S.id , S.address,
FROM STU AS T INNER JOIN STU2 AS S
ON T.id = S.id

要点

  • FROM 中要使用多张表,建议使用别名,提高可读性。
  • 使用ON子句。

    我们可以在ON之后指定两张表联结所使用的列(联结键)。

    在使用到多个联结条件时,可以使用AND,OR进行。

    联结时必须有ON子句,并且要写在FROMWHERE子句之间。
  • 使用联结时SELECT子句中的列需要按照<表的别名>.<列名>的格式进行。

外联结——OUTER JOIN

内联结一样,同样是联结功能。但是只要数据存在于某一表当中,就能够读取出来。而内联结会将那些记录舍去。

虽说如此,但是表中不存在的信息我们还是无法得到,数值都被置位了NULL。

例:

SELECT T.name , T.id , S.class, S.age
FROM STU AS T LEFT OUTER JOIN STU2 AS S
ON T.id = S.id;

外联结要点

  • 选取主表

    在进行外联结的时候,要进行主表的选取。

    使用LEFT或者RIGHT关键字进行主表的选取。

    选取主表之后,就会基于主表,开始进行联结。若主表中有些记录不满足联结的条件,则对应的联结列置位NULL。

    所以结果的记录数应该与主表记录数目相同。

三张表以上的联结

原则上联结表的数量并没有进行限制。

例:

SELECT T.id,T.a ,T.c ,S.a,S.b ,W.a,W.b
FROM STU AS T INNER JOIN STU2 As S
ON T.id = S.id
INNER JOIN STU3 AS W
ON T.id = W.id
WHERE W.id = '111';

按照例程,是一对、一对地嵌套下去。

外联结也是同理。


交叉联结

交叉联结时所有联结运算的基础。但是平时不怎么使用。

对于满足相同规定的表进行交叉连接的集合运算符是

CROSS JOIN(笛卡尔积)

进行交叉联结时无法使用内连接和外联结中所使用的ON子句。因为交叉联结时对两张表中的全部记录进行交叉组合。因此结果中的记录通常是两张表中行数的乘积

结果就是两个表记录的相互组合。

类似于集合的乘法。


SQL入门学习6-集合运算的更多相关文章

  1. SQL基础学习_06_集合运算和联结

    集合运算 1. 并集:UNION     例:     SELECT shohin_id, shohin_mei    FROM Shohin    UNION    SELECT shohin_id ...

  2. SQL Server中的集合运算: UNION, EXCEPT和INTERSECT

    SQL Server中的集合运算包括UNION(合并),EXCEPT(差集)和INTERSECT(相交)三种. 集合运算的基本使用 1.UNION(合并两个查询结果集,隐式DINSTINCT,删除重复 ...

  3. Oracle学习之集合运算

    一.集合运算操作符  UNION:(并集)返回两个集合去掉重复值的所有的记录  UNION ALL:(并集)返回两个集合去掉重复值的所有的记录 INTERSECT:(交集)返回两个集合的所有记录,重复 ...

  4. SQL入门学习3-数据更新

    4-1 数据的插入(INSERT语句的使用方法) 使用INSERT语句可以向表中插入数据(行).原则上,INSERT语句背刺执行一行数据插入. CREATE TABLE 和INSERT 语句,都可以设 ...

  5. SQL入门学习1-查询基础

    2-1 SELECT语句基础 SELECT语句作用 SELECT 语句用于从表中选取数据. 结果被存储在一个结果表中(称为结果集). 重点 使用SELECT语句从表中选取数据. 为列设定显示用的别名 ...

  6. SQL入门学习5-函数、为此、CASE表达式

    6-1. 各种各样的函数 函数的种类 算数函数 字符串函数 日期函数 转换函数 聚合函数 1.1算术函数 数据类型:NUMERIC 是大多数DBMS都支持的一种数据类型. 通过NUMBERIC(全体位 ...

  7. SQL入门学习2-聚合与排序

    3-1 对表进行聚合查询 聚合函数 所谓聚合,就是将多行汇总为一行. 函数名 功能 COUNT 计算表中的记录数(行数) SUM 计算表中数值列的数据合计值 AVG 计算表中数值列的数据平均值 MAX ...

  8. SQL入门学习0-数据库与SQL

    1.1 DBMS DatabaseManagermentSystem 数据库管理系统 DBMS种类 层次型数据库(HDB) 最古老的数据库之一,把数据通过层次结构的方式表现. 关系型数据库(RDB) ...

  9. java入门学习(十二)运算语句 if switch

    这两天在网上做兼职,耽误了些博客见谅哈 欢迎来我的博客:www.taomaipin.com java中的运算语句而且频繁用到的无法就是条件语句和循环语句,包括if,for,while,switch,b ...

随机推荐

  1. 更具体的描述JNI

    JNI事实上,Java Native Interface缩写,也就是说,java本地接口. 它提供了许多API实现和Java并与其他语言的沟通(主要C&C++). 也许很多人认为Java够劲. ...

  2. android studio学习

    http://blog.csdn.net/ryantang03/article/details/8948037 http://www.it165.net/pro/html/201109/676.htm ...

  3. putty中的一些经常使用操作

    (和Linux中操作差点儿相同s) 删除文件夹 rm -rf /home/apache-tomcat-8.0.9 就会把home下的apache-tomcat-8.0.9目录给删除了 删除文件 rm ...

  4. Linux新手命令

    给老婆写了一份速成培训教材--最经常使用的命令及解释.当然每一个人工作内容不同,经常使用命令也不同,这仅仅是我的个人经验,并且要考虑到接受者的基础. ls:列出文件夹下的内容,类似于dos下的dir. ...

  5. 【原创】UVAOJ水题10025解题报告

    首先是原题,转自UVAOJ  The ? 1 ? 2 ? ... ? n = k problem  The problem Given the following formula, one can s ...

  6. 深入理解spring中的各种注解(转)

    Spring中的注解大概可以分为两大类: 1)spring的bean容器相关的注解,或者说bean工厂相关的注解: 2)springmvc相关的注解. spring的bean容器相关的注解,先后有:@ ...

  7. Ubuntu下搭建ASP.NET 5

    在Ubuntu下搭建ASP.NET 5开发环境   0x00 写在前面的废话 年底这段时间实在太忙了,各种事情都凑在这个时候,没时间去学习自己感兴趣的东西,所以博客也好就没写了.最近工作上有个小功能要 ...

  8. 三种方式上传文件-Java

    前言:负责,因为该项目他(jetty嵌入式开始SpringMvc)实现文件上传的必要性,并拥有java文件上传这一块还没有被曝光.并 Http 更多晦涩协议.因此,这种渐进的方式来学习和实践上载文件的 ...

  9. [LeetCode62]Unique Paths

    题目: A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). ...

  10. YT新人之巅峰大决战03

    题目链接 Problem Description Now give you two integers n m, you just tell me the m-th number after radix ...