资讯专栏INFORMATION COLUMN

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

EasonTyler / 343人阅读

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

前言

接上一篇关系数据库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 就是虚拟表名称。

本文到这里先告一段落,后面会接着更新。
欢迎大家多多指正不足之处。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/17542.html

相关文章

  • 关系据库SQL高级数据查询:重复组合查询连接查询虚拟

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

    kamushin233 评论0 收藏0
  • 关系据库SQL高级数据查询:重复组合查询连接查询虚拟

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

    LiuZh 评论0 收藏0
  • MySQL高级(索引优化+慢查询定位)

    摘要:串行最高的隔离级别,完全服从的隔离级别。但是这将严重影响程序的性能。列显示使用了哪个索引。具体指运行时间超过值的,则会被记录到慢查询日志中。当然,如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会或多或少带来一定的性能影响。 一、先谈谈事务 1. ACID特性 1.1 原子性: 事务是最小的执行单位,不允许分割。事务的原子性确保动作要么全部完成,要么完全不起作用;1.2 ...

    wmui 评论0 收藏0
  • MySQL性能管理及架构设计(二):据库结构优化、高可用架构设计、据库索引优化

    摘要:数据实体之间的逻辑关系,解决数据冗余和数据维护异常。判断标准使用,可以通过输出的列来判断,对于一个索引覆盖查询,显示为查询优化器在执行查询前会决定是否有索引覆盖查询。 上一篇:MySQL性能管理及架构设计(一):什么影响了数据库查询速度、什么影响了MySQL性能 一、数据库结构优化(非常重要) 1.1 数据库结构优化目的     1、减少数据冗余:(数据冗余是指在数据库中存在相同的数据...

    evin2016 评论0 收藏0
  • 数据中台:宜信敏捷数据中台建设实践|分享实录

    摘要:宜信的数据中台是由我们敏捷大数据团队基于四大开源平台开发建设的,因此我们将宜信的数据中台称之为敏捷数据中台。本次分享分为三个部分宜信敏捷数据中台的顶层设计。结合典型案例介绍宜信敏捷数据中台支持哪些数据方面的应用和实践。 内容来源:宜信技术学院第2期技术沙龙-线上直播|宜信敏捷数据中台建设实践 分享嘉宾:宜信数据中台平台团队负责人 卢山巍 导读:宜信于2017年推出了一系列大数据开源工具...

    mtunique 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<