简书作者:seay

  文章出处: 关系数据库SQL之高级数据查询:去重复、组合查询、连接查询、虚拟表

  回顾:【知识库】-数据库_MySQL之基本数据查询:子查询、分组查询、模糊查询

  Learn  [已经过测试校验]

    一、去重复(DISTINCT)

    二、组合查询

    三、UNION(并集)

    四、连接查询

    五、虚拟表

一、去重复(DISTINCT)

  DISTINCT:用于返回唯一不同的值,主要是用于某一字段

  语法

SELECT DISTINCT <列名>|* FROM <表名>

  示例

-- 查询所有班级名称
SELECT DISTINCT Class FROM Students

  

二、组合查询

  SQL组合查询可以使用以下关键字进行操作:

  • UNION(并集):比较两个查询的结果,返回两个集合所有非重复行。
  • INTERSECT(交集):比较两个查询的结果,返回由左右双侧输入查询输出的非重复行。
  • EXCEPT(差集):比较两个查询的结果,返回左侧查询集合中不包含左右集合交集部分的非重复行。
  • 注意:
    使用 EXCEPT 或 INTERSECT 的两个查询的结果集组合起来的基本规则:
    所有查询中的列数和列的顺序必须相同;数据类型必须兼容。

  语法

[SQL查询表达式1]
UNION | INTERSECT | EXCEPT
[SQL查询表达式2];

  基础数据

-- 创建数据表T1
CREATE TABLE T1(
A int NULL,
B int NULL,
C int NULL
);
-- 创建数据表T2
CREATE TABLE T2(
A int NULL,
B int NULL,
C int NULL
);
-- 插入基础数据
INSERT INTO T1 VALUES(1,2,3);
INSERT INTO T1 VALUES(2,3,4);
INSERT INTO T1 VALUES(3,4,5);
INSERT INTO T1 VALUES(4,5,6);
INSERT INTO T1 VALUES(5,6,7);
INSERT INTO T2 VALUES(3,4,5);
INSERT INTO T2 VALUES(5,6,7);
INSERT INTO T2 VALUES(6,7,8);
INSERT INTO T2 VALUES(7,8,9);

三、UNION(并集)

  示例1(去重复)

--查询T1和T2的所有数据,去重复
SELECT * FROM T1 UNION SELECT * FROM T2;

  

  

  示例2(不去重复)

--查询T1和T2的所有数据,不去重复,在UNION关键字后面加上ALL
SELECT * FROM T1 UNION ALL SELECT * FROM T2;

  

  MySQL中没有实现INTERSECT(交集)和EXCEPT(差集)

四、连接查询

  常用的连接查询有如下几种:
  内连接(INNER JOIN):返回连接的对象都满足条件的行。
  左连接(LEFT JOIN):返回左边数据所有数据,即使右边没有数据  (没有对应数据显示为NULL)。
  右连接(RIGHT JOIN):返回右边数据所有数据,即使左边没有数据  (没有对应数据显示为NULL)。
  全连接(FULL JOIN):返回左右交叉数据。
  提示:INNER JOIN 与 JOIN 是相同的。

  语法

SELECT 字段列表 FROM <数据表|视图> INNER JOIN <数据表|视图> ON 条件表达式; 

  数据

  在上一篇【知识库】-数据库_MySQL之基本数据查询:子查询、分组查询、模糊查询基础数据基础上,再增加一些数据。

INSERT INTO Students (Id,Name,Class,Gender,Age,Phone,Address)
VALUES(2016010,'小夏','一班','男',19,'','沈阳');
INSERT INTO Students (Id,Name,Class,Gender,Age,Phone,Address)
VALUES(2016011,'倪妮','二班','女',20,'','北京'); INSERT INTO Scores(SId,CId,Grades,IsPassed) VALUES(2016012,1,90,1);
INSERT INTO Scores(SId,CId,Grades,IsPassed) VALUES(2016012,2,86,1);
INSERT INTO Scores(SId,CId,Grades,IsPassed) VALUES(2016012,3,79,1);

  

  内连接(INNER JOIN)

--查询成绩表并显示课程名称
SELECT S.Id,S.SId,C.Name,S.Grades,S.IsPassed
FROM Scores S INNER JOIN Courses C ON S.CId=C.Id;

  

左连接(LEFT JOIN)

--查询学生信息成绩表
SELECT * FROM Students ST LEFT JOIN Scores S ON ST.Id=S.SId;

  

  

右连接(RIGHT JOIN)

--查询学生信息成绩表
SELECT * FROM Students ST RIGHT JOIN Scores S ON ST.Id=S.SId;

  

   MySQL中不支持全连接(FULL JOIN)

五、虚拟表

  SQL虚拟表是通过SELECT查询语句返回的一个结果集。
  当虚拟表构建出来后,可以直接当作实际数据表一样查询操作,在实际使用中会经常使用到。

  语法

SELECT 字段列表1 FROM
(SELECT 字段列表2 FROM <表名> [WHERE子句]) <虚拟表名称>
[WHERE子句]

  示例

SELECT * FROM ( SELECT S.Id,S.Name CName,S.Grades,S.IsPassed,S.SId,ST.Name,ST.Class
FROM Students ST LEFT JOIN (SELECT Scores.*,C.Name FROM
Scores LEFT JOIN Courses C ON Scores.CId=C.Id) S ON ST.Id=S.SId ) T

  

  【示例中的SELECT Scores.*,C.Name FROMScores LEFT JOIN Courses C ON Scores.CId=C.Id中 C 和最后面 T 就是虚拟表名称。】

【知识库】-数据库_MySQL之高级数据查询:去重复、组合查询、连接查询、虚拟表的更多相关文章

  1. 关系数据库SQL之高级数据查询:去重复、组合查询、连接查询、虚拟表

    前言 接上一篇关系数据库SQL之基本数据查询:子查询.分组查询.模糊查询,主要是关系型数据库基本数据查询.包括子查询.分组查询.聚合函数查询.模糊查询,本文是介绍一下关系型数据库几种高级数据查询SQL ...

  2. mysql常用基础操作语法(八)~~多表查询合并结果和内连接查询【命令行模式】

    1.使用union和union all合并两个查询结果:select 字段名 from tablename1 union select 字段名 from tablename2: 注意这个操作必须保证两 ...

  3. Mysql学习总结(24)——MySQL多表查询合并结果和内连接查询

    1.使用union和union all合并两个查询结果:select 字段名 from tablename1 union select 字段名 from tablename2: 注意这个操作必须保证两 ...

  4. MySQL 查询语句--------------进阶6:连接查询

    #进阶6:连接查询 /* 含义:多个表格连接,当查询的字段来自于多个表时候,就会用到连接查询 我觉得这里类似于excel中的vlookup函数 笛卡尔乘积现象:表1有m行,表2有n行,结果有m*n行 ...

  5. SQL Server 不同数据间建立链接服务器进行连接查询

        在平时查询以及导数据时,经常会遇到需要使用两个数据库里数据的情况,这时就会用到在两个服务器之间建立一个链接,进行操作,脚本语句如下: 举例:例如你在测试服务器上想要查询业务库里的数据信息,此脚 ...

  6. Excel 表格查找重复数据,去重复统计

    找出表格是否有重复数据: =IF(AND(G20=G19,D20=D19),"是","否") 筛选移除[重复的数据]然后开始统计 =SUBTOTAL(9,E2: ...

  7. DataTable相关操作,筛选,取前N条数据,去重复行,获取指定列数据

    #region DataTable筛选,排序返回符合条件行组成的新DataTable或直接用DefaultView按条件返回      /// <summary>      /// Dat ...

  8. mysql求交集:UNION ALL合并查询,inner join内连接查询,IN/EXISTS子查询

    两个要求交集的表(列)的结构要一致,对应的字段数,字段类型都应该相同:将两个数据的数据列用 UNION ALL 关键字合并:将上面的所有需要比较的列 GROUP BY :最后 HAVING COUNT ...

  9. 【MySQL作业】外连接查询——美和易思外连接查询应用习题

    点击打开所使用到的数据库>>> 1.使用左接获取所有客户的基本信息以及订购信息,要求输出客户姓名.电话.订单 ID 和下单时间. 由于需要获取所有客户的基本信息,如果采用左连接加以实 ...

随机推荐

  1. MySQL mysql-5.7.21-winx64.zip安装指南

    一.下载mysql-5.7.21-winx64.zip压缩包 二.解压 1.在目录mysql-5.7.21-winx64下新建data文件夹 !!!如果已经存在data文件夹,请删除其中ib_logf ...

  2. nop4.1学习ServiceCollectionExtensions(二)(ioc,ef,ef连接的实现)

    这个是获取程序路径,并初始化文件管理类 初始化插件管理 接下来就是注册服务和autoafc 在INopStartup配置sql连接,插件,mvc等 配置了sql连接 数据库的配置类 在AddAutoM ...

  3. 实现双向绑定Proxy比defineproperty优劣如何?

    前言 双向绑定其实已经是一个老掉牙的问题了,只要涉及到MVVM框架就不得不谈的知识点,但它毕竟是Vue的三要素之一. Vue三要素 响应式: 例如如何监听数据变化,其中的实现方法就是我们提到的双向绑定 ...

  4. 创建json对象

    jQuery创建json对象 方法二: <!DOCTYPE html> <html> <head> <meta charset="utf-8&quo ...

  5. fetch的文件流下载及下载进度获取

    下载过程中,获取进度,fetch API并没有提供类似xhr和ajax的 progress所以用 getReader()来循环读取大小 let size = 0; fetch( URL() + `/s ...

  6. 第九章、import 和from ...import

    目录 第九章.import 和from ...import 一.import和 from ...import ... 二.import模块名 第九章.import 和from ...import 一. ...

  7. 解决办法:Message: 对实体 "useUnicode" 的引用必须以 ';' 分隔符结尾

    Hibernate 5.3.1 INFO: HHH000206: hibernate.properties not foundException in thread "main" ...

  8. Web开发的分层结构与MVC模式

    1.分层结构 所谓分层结构.把不同的功能代码封装成类,把相同功能的类封装在一个个的包中,也叫层.功能归类如下: 实体类: 封装数据,是数据的载体,在层与层之间进行传递,数据也就传递了.比如说要传递学生 ...

  9. leetcode第6题:Z字形变换--直接模拟求解法

    [题目描述] 将一个给定字符串根据给定的行数,以从上往下.从左到右进行 Z 字形排列. 比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下: 之后,你 ...

  10. 使用browsercookie来管理浏览器cookies

    处理cookie是很繁琐的一件事情,稍微有一点处理不对的话,就不能访问网站,最好的办法就是能操作浏览器cookie,这样是最真实的,在Python中有一个第三方库: browsercookie就是来解 ...