关系数据库SQL之高级数据查询:去重复、组合查询、连接查询、虚拟表
前言
接上一篇关系数据库SQL之基本数据查询:子查询、分组查询、模糊查询,主要是关系型数据库基本数据查询。包括子查询、分组查询、聚合函数查询、模糊查询,本文是介绍一下关系型数据库几种高级数据查询SQL语法,包括虚拟表、去重复查询、组合查询、连接查询。

去重复(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;

INTERSECT(交集)
--查询T1和T2的交集
SELECT * FROM T1 INTERSECT SELECT * FROM T2;

EXCEPT(差集)
--查询T1和T2的差集
SELECT * FROM T1 EXCEPT SELECT * FROM T2;

连接查询
常用的连接查询有如下几种:
内连接(INNER JOIN):返回连接的对象都满足条件的行。
左连接(LEFT JOIN):返回左边数据所有数据,即使右边没有数据
(没有对应数据显示为NULL)。
右连接(RIGHT JOIN):返回右边数据所有数据,即使左边没有数据
(没有对应数据显示为NULL)。
全连接(FULL JOIN):返回左右交叉数据。
提示:INNER JOIN 与 JOIN 是相同的。
语法
SELECT 字段列表 FROM <数据表|视图> INNER JOIN <数据表|视图> ON 条件表达式;
数据
在上一篇关系数据库SQL之基本数据查询:子查询、分组查询、模糊查询基础数据基础上,再增加一些数据。
INSERT INTO Students (Id,Name,Class,Gender,Age,Phone,[Address])
VALUES(2016010,'小夏','一班','男',19,'18817716689','沈阳');
INSERT INTO Students (Id,Name,Class,Gender,Age,Phone,[Address])
VALUES(2016011,'倪妮','二班','女',20,'18817716698','北京');
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;

全连接(FULL JOIN)
--查询学生信息成绩表
SELECT * FROM Students ST FULL JOIN Scores S ON ST.Id=S.SId;

虚拟表
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 就是虚拟表名称。

本文到这里先告一段落,后面会接着更新。
欢迎大家多多指正不足之处。
关系数据库SQL之高级数据查询:去重复、组合查询、连接查询、虚拟表的更多相关文章
- SQL Server 不同数据间建立链接服务器进行连接查询
在平时查询以及导数据时,经常会遇到需要使用两个数据库里数据的情况,这时就会用到在两个服务器之间建立一个链接,进行操作,脚本语句如下: 举例:例如你在测试服务器上想要查询业务库里的数据信息,此脚 ...
- 【知识库】-数据库_MySQL之高级数据查询:去重复、组合查询、连接查询、虚拟表
简书作者:seay 文章出处: 关系数据库SQL之高级数据查询:去重复.组合查询.连接查询.虚拟表 回顾:[知识库]-数据库_MySQL之基本数据查询:子查询.分组查询.模糊查询 Learn [已经过 ...
- mysql常用基础操作语法(八)~~多表查询合并结果和内连接查询【命令行模式】
1.使用union和union all合并两个查询结果:select 字段名 from tablename1 union select 字段名 from tablename2: 注意这个操作必须保证两 ...
- Mysql学习总结(24)——MySQL多表查询合并结果和内连接查询
1.使用union和union all合并两个查询结果:select 字段名 from tablename1 union select 字段名 from tablename2: 注意这个操作必须保证两 ...
- MySQL 查询语句--------------进阶6:连接查询
#进阶6:连接查询 /* 含义:多个表格连接,当查询的字段来自于多个表时候,就会用到连接查询 我觉得这里类似于excel中的vlookup函数 笛卡尔乘积现象:表1有m行,表2有n行,结果有m*n行 ...
- Excel 表格查找重复数据,去重复统计
找出表格是否有重复数据: =IF(AND(G20=G19,D20=D19),"是","否") 筛选移除[重复的数据]然后开始统计 =SUBTOTAL(9,E2: ...
- DataTable相关操作,筛选,取前N条数据,去重复行,获取指定列数据
#region DataTable筛选,排序返回符合条件行组成的新DataTable或直接用DefaultView按条件返回 /// <summary> /// Dat ...
- SQL学习之数据列去空格函数
1.LTRIM()---去掉列值左边的空格 如下代码: select * from dbo.course where tno='t003' and cno='c0013'
- oracle sql 当初始化数据时避免重复主键
一:当有主键序列自动增长时候(序列为:seq_cct_id) insert into cs_cost_type (CCT_ID, CCT_NAME, CCT_RATE, CCT_RATE_TYPE, ...
随机推荐
- SQL Server的镜像是基于物理块变化的复制 镜像Failover之后数据的预热问题
SQL Server的镜像是基于物理块变化的复制 镜像Failover之后数据的预热问题 基于物理块变化的复制,没有并行也是很快的. 逻辑复制的日志是按事务结束的时间排序的,而物理复制是与事务无关的, ...
- DRY(Don't Repeat Yourself )原则
凡是写过一些代码的程序猿都能够意识到应该避免重复的代码和逻辑.我们通过提取方法,提取抽象类等等措施来达到这一目的.我们总能时不时的听到类似这样的话:”把这些公用的类放到shared项目去,别的项目还要 ...
- IIS发布站点错误收集(持续更新)
本文主要收集IIS在发布站点过程中遇到的错误,并提供解决办法.并亲测可行.如果您也在使用IIS发布站点的过程中遇到了一些问题,欢迎留言提问. (1.) HTTP错误500.21-Internal Se ...
- .NET垃圾回收(GC)原理
作为.NET进阶内容的一部分,垃圾回收器(简称GC)是必须了解的内容.本着“通俗易懂”的原则,本文将解释CLR中垃圾回收器的工作原理. 基础知识 托管堆(Managed Heap) 先来看MSDN的解 ...
- iOS block种类和切换
block 分为三种 NSGlobalBlock,NSStackBlock, NSMallocBlock. NSGlobalBlock:类似函数,位于text段: NSStackBlock:位于栈内存 ...
- 通过圆形载入View了解自定义View
这是自定义View的第一篇文章,通过制作简单的自定义View来了解自定义View的流程. 自定义View是Android学习和开发中必不可少的一部分.通过自定义View我们可以制作丰富绚丽的控件,自定 ...
- mybatis中的#和$的区别
#相当于对数据 加上 双引号,$相当于直接显示数据 1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号.如:order by #user_id#,如果传入的值是111,那么解析成sq ...
- JS原生第八篇 (帅哥)
1.1 复习 1. clientX clientWidth 可视区域的宽度 clientWidth width + padding offsetWidth ...
- JS原生第五篇 (帅哥)
1.1 节点 1. 节点 网页是有很多的节点组成的 . 元素节点 指的是 : 标签 li span 文本节点 属性节点 父子兄弟 父 parent ...
- jQuery通过parent()和parents()方法访问父级元素
<div class="inputGroup"> <p>2.您的最高学历是?</p> <label><input type=& ...