`

SQL的JOIN、并集、差集、交集

    博客分类:
  • SQL
阅读更多

1、Union形成并集

       Union可以对两个或多个结果集进行连接,形成“并集”。子结果集所有的记录组合在一起形成新的结果集。

       1.1、限定条件

         要是用Union来连接结果集,有4个限定条件。

         (1)、子结果集要具有相同的结构。

         (2)、字结果集的列数必须相同。

         (3)、子结果集对应的数据类型必须可以兼容。

         (4)、每个子结果集不能包含order by和compute子句。

  1.2、语法形式

         select statement from tableName1 union[all] select statement from tableName1

         all代表最终的结果集中将包含所有的行,而不能删除重复行

         示例1:删除重复行

SELECT Name FROM Person_1
UNION
SELECT Name FROM Person_2

     示例2:显示全部,不删除重复行 

SELECT Name FROM Person_1
UNION ALL
SELECT Name FROM Person_2

2、Except形成差集

       Except可以对两个或多个结果集进行连接,形成“差集”。返回左边结果集合中已经有的记录,而右边结果集中没有的记录。

       2.1、限定条件:

         (1)、子结果集要具有相同的结构。

         (2)、子结果集的列数必须相同。

         (3)、子结果集对应的数据类型必须可以兼容。

         (4)、每个子结果集不能包含order by 和 compute子句。

       2.2、语法形式:

         select statement from tableName1 except select statement from tableName1

         示例:

SELECT Name FROM Person_1
EXCEPT
SELECT Name FROM Person_2

4、minus-(oracle)

返回在第一个查询结果中与第二个查询结果不相同的那部分行记录,
即两个结果的差集

SELECT Name FROM abc2
minus
SELECT Name FROM abc

 

5、InterSect形成交集

       InterSect可以对两个或多个结果集进行连接,形成“交集”。返回左边结果集和右边结果集中都有的记录。

  3.1、限定条件  

         要是用Except来连接结果集,有4个限定条件。

         (1)、子结果集要具有相同的结构。

         (2)、子结果集的列数必须相同。

         (3)、子结果集对应的数据类型必须可以兼容。

         (4)、每个子结果集不能包含order by或compute子句。

  3.2、语法形式

     select statement from tableName1 intersect select statement from tableName1

     示例:

SELECT Name FROM Person_1
INTERSECT
SELECT Name FROM Person_2

4join

 创建测试表

create table table1(id int,name varchar(10))
create table table2(id int,score int)
insert into table1 select 1,'lee'
insert into table1 select 2,'zhang'
insert into table1 select 4,'wang'
insert into table2 select 1,90
insert into table2 select 2,100
insert into table2 select 3,70

如表
-------------------------------------------------
 table1              | table2  |
-------------------------------------------------
id  name          |id  score |
1  lee               |1   90 |
2  zhang          |2  100 |
4  wang           |3   70 |
-------------------------------------------------

以下均在查询分析器中执行

外连接:包括左向外联接、右向外联接或完整外部联接

1、左连接:left join 或 left outer join
  1.1、左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值(null)。
  1.2、sql语句
   select * from table1 left join table2 on table1.id=table2.id
   -------------结果-------------
   id name id score
   ------------------------------
   1 lee 1 90
   2 zhang 2 100
   4 wang NULL NULL

 

  注释:包含table1的所有子句,根据指定条件返回table2相应的字段,不符合的以null显示

2、右连接:right join 或 right outer join
 2.1、右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。
 2.2、sql语句
  select * from table1 right join table2 on table1.id=table2.id
  -------------结果-------------
  id name id score
  ------------------------------
  1 lee 1 90
  2 zhang 2 100
  NULL NULL 3 70

  注释:包含table2的所有子句,根据指定条件返回table1相应的字段,不符合的以null显示

3、完整外部联接:full join 或 full outer join 
 3.1、完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。
 3.2、sql语句
  select * from table1 full join table2 on table1.id=table2.id
  -------------结果-------------
  id name id score
  ------------------------------
  1 lee 1 90
  2 zhang 2 100
  4 wang NULL NULL
  NULL NULL 3 70

  注释:返回左右连接的和(见上左、右连接)

 

内连接:内联接是用比较运算符比较要联接列的值的联接

 1、内连接:join 或 inner join

 2、sql语句
  select * from table1 join table2 on table1.id=table2.id
  -------------结果-------------
  id name id score
  ------------------------------
  1 lee 1 90
  2 zhang 2 100


  注释:只返回符合条件的table1和table2的列

 3、等价(与下列执行效果相同)
A:select a.*,b.* from table1 a,table2 b where a.id=b.id
B:select * from table1 cross join table2 where table1.id=table2.id  (注:cross join后加条件只能用where,不能用on)

 

交叉连接(完全)

1、概念:没有 WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。(table1和table2交叉连接产生3*3=9条记录)

2、交叉连接:cross join (不带条件where...)

3、sql语句
  select * from table1 cross join table2
  -------------结果-------------
  id name id score
  -----------------------------
  1 lee 1 90
  2 zhang 1 90
  4 wang 1 90
  1 lee 2 100
  2 zhang 2 100
  4 wang 2 100
  1 lee 3 70
  2 zhang 3 70
  4 wang 3 70

  注释:返回3*3=9条记录,即笛卡尔积

   4.等价(与下列执行效果相同)
  A:select * from table1,table2        

 

分享到:
评论

相关推荐

    SQL语句的并集UNION 交集JOIN(内连接,外连接)等介绍

    主要介绍了SQL语句的并集UNION,交集JOIN(内连接,外连接),交叉连接(CROSS JOIN笛卡尔积),差集(NOT IN) ,需要的朋友可以参考下

    sql server 2005 技术内幕t-sql查询源码

    3. **集合操作**:可能涉及到并集(UNION)、交集(INTERSECT)和差集(EXCEPT)等集合运算符的使用,以及如何通过这些运算符来合并或比较多个查询结果。 4. **T-SQL流程控制**:讲述如何使用IF...ELSE、WHILE、...

    电子书 SQL语法大全中文版.doc

    合并多个查询结果,分别实现结果集的并集、交集和差集。 12. 函数与表达式: 包括字符串函数、日期时间函数、数学函数、系统信息函数等,用于处理和转换数据。 通过阅读《SQL语法大全中文版》,读者将能够掌握...

    Querying SQL Server 2012 clase database

    5. **Chapter 04 - Working with Sets**: 这一章可能讨论了集合理论和在SQL中处理集合的方法,包括并集、交集和差集,以及集合操作对查询性能的影响。 6. **Chapter 05**: 尽管未提供详细描述,这一章可能涉及了...

    关系代数运算与SQL查询的对应关系

    它通过一套严谨的运算规则,包括并集(Union)、差集(Difference)、交集(Intersection)、笛卡尔积(Cartesian Product)、选择(Selection)、投影(Projection)、连接(Join)和除法(Division),来表达和...

    sql20000 课件

    3. **SQL查询**:学习如何使用SELECT语句进行复杂查询,包括子查询、联接查询、并集、交集和差集操作。 4. **索引与性能优化**:理解索引的作用和类型,如唯一索引、主键索引、非聚簇索引等,并学习如何创建和管理...

    程序员的SQL金典

    在高级查询部分,书中会涉及联接(JOIN)操作,如内连接、外连接和交叉连接,以及子查询和集合操作,如并集、交集和差集。这些内容对于处理多表关联和复杂查询至关重要。同时,还会讨论窗口函数,这是一种强大的工具...

    权威SQL 标准规范文档

    4. **集合操作**:SQL支持并集(UNION)、交集(INTERSECT)和差集(EXCEPT)等集合运算,这些运算符允许你组合多个查询的结果。 5. **视图**:视图是虚拟表,它基于一个或多个表的查询结果。在SQL 2008中,你可以...

    sql99.rar_SQL99 chm_sql_sql 99_sql99_sql99文档下载

    3. **集合操作**:SQL99支持并集(UNION)、交集(INTERSECT)和差集(EXCEPT)操作,允许在多个查询结果之间进行高级组合。 4. **多表操作**:增强了JOIN操作,包括内连接(INNER JOIN)、外连接(LEFT JOIN、...

    Microsoft SQL Server 2005技术内幕:T-SQL查询

    再者,书中会涉及集合操作,如并集(UNION)、交集(INTERSECT)和差集(EXCEPT),以及集合函数,如COUNT、SUM、AVG、MIN和MAX,这些函数用于统计和计算数据。 除了基本查询,书中还将介绍如何使用T-SQL进行数据...

    数据库结构化查询语言SQL

    SQL查询中的逻辑运算符和谓词包括AND、OR、NOT进行逻辑判断,IN、NOT IN用于包含或排除特定值,EXISTS检查子查询是否存在结果,INTERSECT、UNION和MINUS分别用于集合的交集、并集和差集。 以图书管理关系数据模型为...

    Oracle 10g SQL操作和PLSQL所有命令集合

    集合操作包括并集(UNION)、交集(INTERSECT)和差集(MINUS)。 5. **连接查询**:用于合并多个表的数据,依据表之间的关联关系,如内连接(INNER JOIN)、左连接(LEFT JOIN)、右连接(RIGHT JOIN)和全连接...

    McGraw-Hill - Oracle Database 11g SQL (Nov 2007)

    这些高级技巧允许用户合并来自多个表的数据,执行嵌套查询,并处理集合之间的并集、交集和差集。此外,书中还介绍了使用ORDER BY和UNION ALL等语句对结果集进行排序和合并。 在数据操纵方面,本书涵盖了INSERT、...

    SQLServer2008T-SQL查询基础中文版

    7. **集合操作**:UNION、UNION ALL、INTERSECT和EXCEPT用于组合多个查询的结果,分别表示并集、并集(包含重复行)、交集和差集。 8. **函数和表达式**:T-SQL提供了大量内置函数,如字符串函数、日期/时间函数、...

    SQL基础教程PPT

    9. **子查询与集合运算**:讲解如何在查询中嵌套查询(子查询),以及并集(UNION)、交集(INTERSECT)和差集(EXCEPT)的使用。 10. **函数和表达式**:介绍SQL中的内置函数,如字符串函数、日期/时间函数、数学...

    数据库交互式SQL试验报告

    - **集合查询**:包括并集、交集和差集操作。 - **更新操作**: - **插入数据**:`INSERT INTO`语句用于向表中插入新记录。 - **修改数据**:`UPDATE`语句用于修改现有记录,通常与`WHERE`子句一起使用,指定...

    SQL必知必会

    SQL还支持集合操作,如并集(UNION)、交集(INTERSECT)和差集(EXCEPT),这些操作允许对多个查询结果进行合并或比较。 索引是提高查询性能的关键,通过创建索引,可以显著加快数据检索速度。不过,创建过多的...

    Entity_SQL_Framework.docx

    - **Union、Intersect、Except**: 可以使用这些关键字表示并集、交集和差集。 - **Join 表达式**: 支持使用 `JOIN` 语法进行连接操作。 - **级联查询**: 支持类似于 `p.Address.City` 的级联属性访问。 - **不支持的...

    零基础快速自学SQL.rar

    了解如何在查询中嵌套SQL语句,即使用子查询,以及并集(UNION)、交集(INTERSECT)和差集(EXCEPT)等集合操作。 **7. 视图** 视图是虚拟表,基于一个或多个表的查询结果。学习创建、修改和使用视图,可以简化...

Global site tag (gtag.js) - Google Analytics