1 小时 SQL 极速入门(二)

上篇我们说了 SQL 的基本语法,掌握了这些基本语法后,我们可以对单表进行查询及计算分析。但是一个大的系统,往往会有数十上百张表,而业务关系又错综复杂。我们要查的数据往往在好几张表中,而要从多张表中来获取信息就需要用到表联结了。
先说说什么是联结,联结就是用一条 SELECT 语句从多个表中查询数据。通过联结,让多张表中的数据互相关联起来。联结又分为内联结、左外联结、右外联结、全外联结。别怕,我知道有些初学者看到这几个概念就头大,不过请继续往后看,看完后你肯定能看明白。在实际中,内联结和左联结应该是使用最多的,我几乎没用到过右连接与全外联结。
对初学者来说,在这里迷惑的原因是去记这些概念,这是没必要的,我们只要在实际中抱着问题去用一次就可以完全掌握了。
下面我们就开始:
我们有下面三张表,一张订单表存放订单头信息,包括订单号、订单类型、订单数量、订单状态信息。

一张订单明细表,存储订单的详细信息。包含订单号、订单类型、工序号、工序名称、工序状态、物料号、工位号

一张物料表,存储订单工序用到的物料。包含物料号、物料名称。

内联结
我们先观察一下,订单头信息中只包含订单的数量、状态信息。订单明细表中包含着订单的详细信息,如工序信息,每道工序用到的物料,每道工序的名称,在哪个工位操作等信息。假如我们现在要查询订单号、订单数量、工序号、工序名称、工位等信息,只有一张表我们是查不到的,那么我们就要把这两张表结合起来。
SELECT
oh.orderno,
oh.order_type,
oh.quantity,
od.order_line_no,
od.order_line_name,
od.workcenter
FROM
order_header oh
INNER JOIN order_detail od
ON
oh.orderno =od.orderno
AND oh.order_type=od.order_type
解释下:我们用INNER JOIN 表示内连接,在 INNER JOIN 后写上我们需要关联的表,oh 和 od 表示别名,方便后面书写,不然后面我们就要用到表的全称来写了。这里我们要关联到订单明细表 order_detail,去取出订单详细信息。后面跟上 ON 关键字,表示条件,这里 ON 后面有两个条件。表示我们通过订单号和订单类型来把两个表中的数据关联起来,通过订单表中的订单号和订单类型作为条件来查找订单明细表中同样订单号和订单类型的订单的详细信息。
我们看下结果:

可以看到,我们查出了订单 1001 ,1002, 1003, 1004, 1005五个订单的总数量,各个工序的名称,在哪个工位生产等信息。
细心的读者可能会注意到,在订单表中还有一个 1008 的订单,为什么没有查出来?那就接着往下看
左联结
相比于内联结,左联结使用 LEFT JOIN 来表示。我们先不看概念,我们直接把刚才的 SQL 语句改成左联结来看一下结果。
SELECT
oh.orderno,
oh.order_type,
oh.quantity,
od.order_line_no,
od.order_line_name,
od.workcenter
FROM
order_header oh
LEFT JOIN order_detail od
ON
oh.orderno =od.orderno
AND oh.order_type=od.order_type;
结果如下图:

对比内联结的结果,我们发现了什么,我们发现最下面多了一行,1008 订单,而1008 后面的几个字段为空。我们看一下订单明细表会发现没有 1008 这个订单。
这样子我们就明白了,内联结是两张表中都存在才能关联出来。而左联结的意思就是我们的主表中的所有行都会展示出来,如果在联结的表中找不到对应的,会默认为 null.
右联结
知道了左联结,右联结也就清楚了,右连接呢会把我们关联的表中的所有行都展示出来,不管主表中有没有匹配的行。右联结关键字为 RIGHT JOIN
SELECT
oh.orderno,
oh.order_type,
oh.quantity,
od.order_line_no,
od.workcenter
FROM
order_header oh
RIGHT JOIN order_detail od
ON
oh.orderno =od.orderno
AND oh.order_type=od.order_type;

可以看到,RIGHT JOIN 把关联的订单明细表中的所有行都显示了出来,但是订单主表中并没有 1006 和 1007 两个订单,所以这两行显示为 null
多表联结
多表联结就是超过两张表的联结,上面我们关联了订单表和订单明细表,现在我们想知道每道工序用到的物料,就需要关联到物料表。我们看到订单明细表中有 productid 字段,我们用这个关联到 product 表中。同时,后面我们也用了 ORDER BY 进行排序。
SELECT
oh.orderno,
oh.order_type,
oh.quantity,
od.order_line_no,
od.workcenter,
p.productno,
p.product_name
FROM
order_header oh
INNER JOIN order_detail od
ON
oh.orderno =od.orderno
INNER JOIN product1 p
ON
od.productid =p.ID
AND oh.order_type=od.order_type
ORDER BY
orderno,
order_line_no

注意
在使用联结时一定要注意联结条件,如果 联结条件不正确,就会得到不正确的结果。而且要注意,联结条件是必须的。
UNION 与 UNION ALL
UNION 与 UNION ALL 表示并集,可以把两个 SELECT 查询的结果合并成一个,前提是两个 SELECT 所查询的列数量和字段类型一致。不同的是 UNION 会去除重复行,而 UNION ALL 不会去除重复行。
如果我们有两张表,都存有相似的信息。比如我们在一个其他表中也存储的有订单信息。举个栗子,order_header_bak 表中存有如下两条数据。

我们用 UNION ALL 试一下
SELECT
orderno,
order_type,
order_status
FROM
order_header
UNION ALL
SELECT
orderno,
order_type,
order_status
FROM
order_header_bak;

看到查出了 8 条信息,1001 订单有两条一样的信息。
我们用 UNION 试一下
SELECT
orderno,
order_type,
order_status
FROM
order_header
UNION
SELECT
orderno,
order_type,
order_status
FROM
order_header_bak

看到只有 7 条数据了, 1001 订单只有一行数据。
1 小时 SQL 极速入门(二)的更多相关文章
- 1 小时 SQL 极速入门(三)——分析函数
1 小时 SQL 极速入门 前面两篇我们从 SQL 的最基础语法讲起,到表联结多表查询. 大家可以点击链接查看 1 小时 SQL 极速入门(一) 1 小时 SQL 极速入门(二) 今天我们讲一些在做报 ...
- 1 小时 SQL 极速入门(一)
前几天,我在论坛溜达.看到一个人发帖说 做了6年的企业级开发,总是被互联网行业的人认为没技术含量,不就是CRUD么 先解释下 CRUD 是什么.CRUD 就是我们常说的增删改查(Create,Retr ...
- sql xml 入门 (二)
DECLARE @myDoc xml --http://www.paymob.cn --话费充值api,充值api,话费充值接口,手机话费充值,车贝手机,贝萌手机,移动话费充值,联通话费充值,电信话费 ...
- Unity3D新手教学,让你十二小时,从入门到掌握!(三 ) [转]
版权声明:本文为Aries原创文章,转载请标明出处.如有不足之处欢迎提出意见或建议,联系QQ531193915 这一讲,我会教大家如何写碰撞检测的代码,然后还会教大家如何使用我介绍给大家的第一个Uni ...
- Unity3D新手教学,让你十二小时,从入门到掌握!(二) [转]
版权声明:本文为Aries原创文章,转载请标明出处.如有不足之处欢迎提出意见或建议,联系QQ531193915 继续上一讲的内容,首先呢, 为了接下来要做的小游戏,在这里我要小小的修改一下移动的代码. ...
- 《Python黑客编程之极速入门》正式开课
玄魂 玄魂工作室 今天 之前开启了一个<Python黑客编程>的系列,后来中断了,内容当时设置的比较宽,不太适合入门.现在将其拆分成两个系列<Python黑客编程之极速入门>和 ...
- SQL 存储过程入门(事务)(四)
SQL 存储过程入门(事务)(四) 本篇我们来讲一下事务处理技术. 为什么要使用事务呢,事务有什么用呢,举个例子. 假设我们现在有个业务,当做成功某件事情的时候要向2张表中插入数据,A表,B表,我 ...
- SQL从入门到基础–03 SQLServer基础1(主键选择、数据插入、数据更新)
一.SQL语句入门 1. SQL语句是和DBMS“交谈”专用的语句,不同DBMS都认SQL语法. 2. SQL语句中字符串用单引号. 3. SQL语句中,对于SQL关键字大小写不敏感,对于字符串值大小 ...
- 每篇半小时1天入门MongoDB——2.MongoDB环境变量配置和Shell操作
上一篇:每篇半小时1天入门MongoDB——1.MongoDB介绍和安装 配置环境变量 Win10系统为例 右键单击“此电脑”——属性——高级系统设置——高级——环境变量,添加C:\Program F ...
随机推荐
- 【算法】Normalization
Normalization(归一化) 写这一篇的原因是以前只知道一个Batch Normalization,自以为懂了.结果最近看文章,又发现一个Layer Normalization,一下就懵逼了. ...
- springboot 错误求解决
最近再学习springboot这个好东西,结果给当成白老鼠了,我使用的是idea 2018 来测试 一个简单的界面跳转 ,结果报错了,在网上搜了好半天没搜到相应的解决方案,很头疼,希望哪位大神能 ...
- Javascript数据结构与算法--队列(顺序队列、优先队列、循环队列)的实现与用法
前言 队列和栈非常类似,前面已经讲过了栈的实现与用法,现在我们来说说队列. 队列介绍 队列遵循FIFO(First In First Out,先进先出)原则的一组有序的项. 队列是一种特殊的线性表,特 ...
- ELK配置
安装logstash docker pull logstash docker run -it --rm logstash -e 'input { stdin { } } output { stdout ...
- ASP.NET MVC 执行流程介绍
Routing 组件 Controller Controller中可用的ActionResult MVC-View(使用的抽象工厂模式的视图引擎) 视图模型
- yarn一直在跑一个用户为dr.who的application
现象: 访问yarn:8088页面发现一直有任务在跑如图: 用户为dr.who,问下内部使用人员,都没有任务在跑: 结论: 恭喜你,你中毒了,攻击者利用Hadoop Yarn资源管理系统REST AP ...
- 跟大家谈一谈:涛舅舅家的微信域名检测api的心路历程
微信域名检测,这是近一年来兴起来的一种网络服务,可以通过api接口来对域名进行批量检测,以确认该域名有没有被微信拦截(见红),然后通过编程来实现域名切换保障链接可以正常打开. 涛舅舅工作室从事微信域名 ...
- 20162329张旭升 2018-2019-2《网络对抗技术》第1周 Kali的安装
目录 Kali的安装 设置与主机的文件交互 Kali的安装 1.创建虚拟机 2.选择安装语言 3.设置网络 4.设置分区 5.安装完成 设置与主机的文件交互 首先在vmware workstation ...
- 如何查找MySQL中查询慢的SQL语句(转载)
转载自https://www.cnblogs.com/qmfsun/p/4844472.html 如何在mysql查找效率慢的SQL语句呢?这可能是困然很多人的一个问题,MySQL通过慢查询日志定位那 ...
- Java当中的线程
1.进程和线程 进程和线程之间是什么关系 多进程:在操作系统中能(同时)运行多个任务(程序) 多线程:在同一应用程序中有多个顺序流(同时)执行 线程的执行过程 2.定义线程的方法 方法1: 定义一个线 ...