`

转: SQL 操作结果集 -并集、差集、交集、结果集排序 操作结果集

阅读更多

原文转载自:http://www.cnblogs.com/kissdodog/archive/2013/06/24/3152743.html

 

以下为转载内容:

为了配合测试,特地建了两个表,并且添加了一些测试数据,其中重复记录为东吴的人物。

表:Person_1魏国人物

表:Person_2蜀国人物

A、Union形成并集

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

1、限定条件:

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

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

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

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

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

 

2、语法形式

select_statement union [all] select_statement

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

 

3、示例:

SELECT Name FROM Person_1
UNION
SELECT Name FROM Person_2

生成的结果为:

注意到重复记录,孙权与周瑜仅仅显示了一个。下面来将UNION替换成UNION ALL看看是什么结果:

SELECT Name FROM Person_1
UNION ALL
SELECT Name FROM Person_2

 注意到重复记录,孙权与周瑜出现了两次,这就是UNION ALL 与 UNION的不同之处。

 

B、Except形成差集

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

1、限定条件:

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

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

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

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

 

2、语法形式:

select_statement except select_statement

自动删除重复行。

 

3、示例:

SELECT Name FROM Person_1
EXCEPT
SELECT Name FROM Person_2

 结果:

留意到表Person_2有的,孙权周瑜已被去除。

 

C、InterSect形成交集

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

1、限定条件:

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

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

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

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

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

 

2、语法形式:

select_statement intersect select_statement
3、示例:
SELECT Name FROM Person_1
INTERSECT
SELECT Name FROM Person_2
 返回的结果如下:


留意到只取两张表都有的记录(周瑜,孙权),这就是所谓的交集。

 

 D、结果集的排序 

SELECT Name FROM Person_1
INTERSECT
SELECT Name FROM Person_2
ORDER BY Name DESC    --此处的字段名相同了,如果不同,请切记排序列名,只能够是第一个表的列名

这里只有两点要注意:

1.ORDER BY是对整个运算后的结果排序,并不是对单个数据集。

2.ORDER BY后面排序的字段名称是第一个数据集的字段名或者别名。

  • 大小: 17.6 KB
  • 大小: 17.5 KB
  • 大小: 11.5 KB
  • 大小: 14.2 KB
  • 大小: 7.3 KB
  • 大小: 5.7 KB
分享到:
评论

相关推荐

    sql server 交集,差集的用法详解

    UNION集合运算可以将两个输入查询的结果组合成一个结果集。需要注意的是:如果一个行在任何一个输入集合中出现,它也会在UNION运算的结果中出现。T-SQL支持以下两种选项: (1)UNION ALL:不会删除重复行 -- union...

    (第二卷)Microsoft SQL Server 2008技术内幕:T-SQL语言基础

     《Microsoft SQL Server 2008技术内幕:T-SQL语言基础》适合须要学习T-SQL的各级程序员和数据库专业人员,是他们快速掌握T-SQL的必备参考图书。 致谢 引言 第1章 T-SQL查询和编程基础 1.1 理论背景 1.2 ...

    (第一卷)Microsoft.SQL.Server.2008技术内幕:T-SQL语言基础

     《Microsoft SQL Server 2008技术内幕:T-SQL语言基础》适合须要学习T-SQL的各级程序员和数据库专业人员,是他们快速掌握T-SQL的必备参考图书。 致谢 引言 第1章 T-SQL查询和编程基础 1.1 理论背景 1.2 SQL ...

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

     2.5 同时操作(ALL-AT-ONCE OPERATION)  2.6 处理字符数据  2.7 处理日期和时间数据  2.8 查询元数据  2.9 总结  2.10 练习  2.11 解决方案 第3章 联接查询  3.1 交叉联接  3.2 内联接  3.3 ...

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

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

    技巧篇:pyspark常用操作梳理

    pyspark常用操作梳理 基于spark.sql进行操作 创建临时表 创建临时视图 基于dataframe进行操作 了解表结构 查看数据 查看列名 持久化 列操作 列名称重命名 ... 利用pandas取差集、交集和并集

    LINQ操作数组代码(交集,并集,差集,最值,平均,去重复)

    数组是大学里经常拿来做算法练习的对象。一些经典算法非常有价值,考试、装逼、面试都十分有用。但现在是效率时代,编程讲究生产效率,利用LINQ,可以让程序猿避免写一些基本算法,把精力花在业务处理上

    2023最新Java面试题

    这些数据结构都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,Redis支持各种不同方式的排序。为了保证效率,数据都是缓存在内存中,Redis会周期性地把更新的...

    QDAC下载_开源Delphi数据库组件

    QDAC核心为TMemoryDataSet组件,它可以实现数据集的克垄多种方式复制数据集、过滤SQL操作符、多表的并集、交集和差集、内存排序支持、导入导出、连接到PostgreSQL等功能,是从事Delphi数据库开发强大的辅助组件。

    orcale常用命令

    列出全部SQL命令和SQL*Plus命令 SQL>help 列出某个特定的命令的信息 SQL>help 命令名 c、显示表结构命令DESCRIBE SQL>DESC 表名 d、SQL*Plus中的编辑命令 显示SQL缓冲区命令 SQL>L 修改SQL命令 首先要将待改正行...

    mysql进阶(二).pdf

    多表查询;交集、并集、差集;DCL管理用户授权;mysql架构;存储引擎;锁;事务;业务设计;物理设计;慢查询;

    最全的oracle常用命令大全.txt

    列出全部SQL命令和SQL*Plus命令 SQL>help 列出某个特定的命令的信息 SQL>help 命令名 c、显示表结构命令DESCRIBE SQL>DESC 表名 d、SQL*Plus中的编辑命令 显示SQL缓冲区命令 SQL>L 修改SQL命令 首先要将待改正行...

    开发经常遇到的安全处理

    redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list...这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。

Global site tag (gtag.js) - Google Analytics