关系数据库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.IsPassedFROM 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 FROMScores 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之高级数据查询:去重复、组合查询、连接查询、虚拟表相关推荐
- 爬虫 spider09——爬取指定数据,去重复,并存储到mysql
爬取指定数据,去重复,并存储到mysql. 技术栈:Springboot+ssm+定时(定时器)爬取+redis去重+mybatis保存 一.创建父项目Spider pom.xml <?xml ...
- 周末杂谈:在MYSQL中,添加数据行后,使用右外连接查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数,表中没有的课程列值为空的解决方法
周末杂谈:在MYSQL中,添加数据行后,使用右外连接查询所有课程的选修情况,要求列出课程编号.课程名称.选修人数,表中没有的课程列值为空的解决方法 实验前期准备 course表(课程表) 在其中: c ...
- c# 访问hbase_大数据技术之C#通过Thrift连接查询HBase主要方法总结
本篇文章探讨了大数据技术之C#通过Thrift连接查询HBase主要方法总结,希望阅读本篇文章以后大家有所收获,帮助大家对相关内容的理解更加深入. 1.get(byte[] tableName,byt ...
- 数据库系统原理与应用教程(047)—— MySQL 查询(九):连接查询
数据库系统原理与应用教程(047)-- MySQL 查询(九):连接查询 目录 数据库系统原理与应用教程(047)-- MySQL 查询(九):连接查询 一.连接查询的语法格式 二.两张表的连接 1. ...
- oracle如何某个字段去重复的数据,Oracle 去重复的数据
重复的数据分两种,一种是表中部分字段的重复,一种是两行以上的记录完全一样. 部分字段的重复: 查询不重复的数据SQL: select 字段1,字段2,count(*) from 表名 group by ...
- mysql查询不重复记录数_mysql查询不重复的行内容,不重复的记录数.count,distinct
有这么一个表 记录了id, p_id, p_name , p_content , p_time 1 343 aaa aaaaaa 2012-09-01 2 344 bbb bbbbbb 2012-09 ...
- SQL数据库语言基础之SqlServer多表连接查询与INNER JOIN内连接查询
文章目录 一.简单连接查询 二.多表连接查询 三.INNER JOIN 内连接查询 一.简单连接查询 1.直接连接:无连接规则连接两表,得到的是两个表的笛卡尔积. 连接后的行数=表1行数*表2行数 连 ...
- mysql 子查询 主键外键_MySQL查询优化:用子查询代替非主键连接查询实例介绍
一对多的两张表,一般是一张表的外键关联到另一个表的主键.但也有不一般的情况,也就是两个表并非通过其中一个表的主键关联. 例如: create table t_team ( tid int primar ...
- mysql常用基础操作语法(八)~~多表查询合并结果和内连接查询【命令行模式】...
1.使用union和union all合并两个查询结果:select 字段名 from tablename1 union select 字段名 from tablename2: 注意这个操作必须保证两 ...
最新文章
- android SDK Manager 代理服务器设置
- poj 1067 取石子游戏(博弈+威佐夫博奕(Wythoff Game))
- Codeforces Round #701 (Div. 2) D. Multiples and Power Differences 思维构造
- Spring框架中的内容协商
- 简单shell:删除五日之前的日志文件
- extjs 关闭弹出窗口_【实用工具】一键关闭/开启Windows防火墙、禁止更新系统
- 《如何搭建小微企业风控模型》第十节 单变量分析(下)节选
- web安全day44:进阶,使用Nmap+Wireshark理解端口扫描
- CAD如何导出PDF格式
- C语言冒泡排序算法详解
- C++Builder实现鼠标钩子
- 如何开启win10自带的五笔输入法,并把字库切换成五笔98版
- android操作蓝牙打印机(上)
- python豆瓣mysql_python爬虫获取豆瓣电影——Python操作MySQL存储数据
- Java程序监控工具
- 不同麻醉方案以及清醒条件下大鼠大脑连接模式分析
- CAS操作实际上包含了哪两个步骤?
- node+express实现文件上传功能
- 2-VIV-Android控件之res资源加载
- USB转多串口产品设计