SQL语法(五) 多表联合查询

SQL语法(五) 多表联合查询前言当需要获取的数据分布在多张中,考虑使用联合查询,本章将学习两种查询方式(sql92/sql99)范例1.笛卡儿积将多个表的数据进行一一对应,所得到结果为多表的笛卡尔积。结果的数量为所有表的数量的乘积。–SQL92方式–表名以逗号隔开实现多表查询–SQL99方式–使用crossjoin关键字2.等值连接筛选&不等…

大家好,又见面了,我是你们的朋友全栈君。

前言

           当需要获取的数据分布在多张中,考虑使用联合查询,本章将学习两种查询方式(sql92/sql99)

范例

1.笛卡儿积

将多个表的数据进行一一对应,所得到结果为多表的笛卡尔积。结果的数量为所有表的数量的乘积。

–SQL92方式
  –表名以逗号隔开实现多表查询
–SQL99方式
  –使用cross join 关键字

SQL语法(五) 多表联合查询

2.等值连接筛选&不等值连接筛选(内连接)

–概念:先做表的笛卡尔积,然后筛选,筛选条件为等值筛选。
–注意:条件为字段的值相同(字段值条件)来进行筛选,字段的名字可以不同

–SQL92方式
  –where 筛选条件…
–SQL99方式
  –使用natural join 表名(自然连接,根据名称相同字段进行等值连接)
  –使用(inner) join 表名 on 筛选条件…    (内连接,根据筛选条件进行等值/不等值连接,inner关键字可以省略不写)
  –使用(inner) join 表名 using(字段名,字段名,….)  (内连接,根据名称相同字段进行等值连接,可指定字段,inner关键字可以省略)

SQL语法(五) 多表联合查询

SQL语法(五) 多表联合查询

SQL语法(五) 多表联合查询

3.自连接

SQL语法(五) 多表联合查询

4.外连接

(1)左外连接

–SQL92方式
  –where子句中在右边连接字段后加 (+),显示左边对应字段没有值的数据
–SQL99方式
  –select 内容 from 表名 left (outer) join 表名 on 连接条件 (外连接,outer可以省略不写)

SQL语法(五) 多表联合查询

(2)右外连接

–SQL92方式
  –where子句中在左边连接字段后加 (+),显示右边对应字段没有值的数据
–SQL99方式
  –select 内容 from 表名 right (outer) join 表名 on 连接条件 (外连接,outer可以省略不写)

SQL语法(五) 多表联合查询

(3)满外连接

–SQL92方式
  无
–SQL99方式
  –select 内容 from 表名 full (outer) join 表名 on 连接条件 (外连接,outer可以省略不写)

SQL语法(五) 多表联合查询

附录:多表联合查询示例(SQL99)

--查询所有数据
select * from EMP for update;

--笛卡尔积 (1,2,3) (5,6,7)
--SQL92,SQL99(推荐)
--使用 cross join 关键字
select * from emp cross join dept;--15*4=60

--等值连接和不等值连接(内连接)
--先做笛卡尔积,然后根据条件进行筛选
--注意:条件为字段的值相同来进行筛选,字段的名字可以不同

--等值连接
       --自然连接:根据名称相同字段进行等值连接
       --使用 natural join关键字
       select * from emp natural join dept;
       --名称字段不相同
       -- 表一 inner join 表二 on 筛选条件
       select * from emp e inner join dept t on e.deptno = t.deptno;
       --名称字段相同也可以使用
       -- 表一 inner join 表二 using (字段名,字段名...)
       select * from emp join dept using (deptno);
--不等值连接
   select * from emp e inner join dept t on e.sal between 1000 and 1500;

--自连接
   select * from emp a inner join emp b on a.empno = b.mgr;


--外连接

--左外连接
-- 表一 left (outer) join 表二 on 筛选条件
select * from emp e left join dept t on e.deptno = t.deptno;

--右外连接
-- 表一 right (outer) join 表二 on 筛选条件
select * from emp e right join dept t on e.deptno = t.deptno;

--满外连接
-- 表一 full (outer) join 表二 on 筛选条件
select * from emp e full join dept t on e.deptno = t.deptno;

附录:操作视频

SQL语法之多表联合查询

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/131535.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月12日 上午9:36
下一篇 2022年6月12日 上午9:36


相关推荐

  • 使用prometheus和grafana监控springboot应用

    使用prometheus和grafana监控springboot应用

    2021年5月15日
    105
  • 【损失函数系列】softmax loss损失函数详解

    【损失函数系列】softmax loss损失函数详解1.损失函数:损失函数(lossfunction)是用来评测模型的预测值f(x)与真实值Y的相似程度,损失函数越小,就代表模型的鲁棒性越好,损失函数指导模型学习。根据损失函数来做反向传播修改模型参数。机器学习的目的就是学习一组参数,使得预测值与真值无限接近。2.softmaxloss:它是损失函数的一种,是softmax和cross-entropyloss组合而成的损失函数。先看softmax,其函数形式如下:其中zj就是某个神经网络全连…

    2022年6月26日
    75
  • 计算器原码、反码和补码和位移的一些总结

    计算器原码、反码和补码和位移的一些总结计算器原码 反码和补码的一些基础知识 来自百度百科的一些概念解释 在计算机系统中 数值一律用补码来表示和存储 原码一般是针对用户而言 补码是针对计算机的具体存储来使用 转换关系 1 正整数 负整数 转换如何转换为补码 a 正整数的补码是其二进制表示 与原码相同 例 1 9 的补码是 00001001 备注 这个 9 的补码是用 8 位 2 进制来表示的 补码表示方式很多 还有 16 位二

    2026年3月26日
    2
  • java语言打印出菱形_java怎么打印菱形

    java语言打印出菱形_java怎么打印菱形Java典型例题(打印菱形)题目:利用*号打印出一个菱形图样分析:下面逐步分析菱形打印的推演过程推演过程利用单独的方法演示,使用时直接在主方法中调用对应的方法即可。第一步,打印一行*号/**打印出如下图形: ********/publicstaticvoidprint01(){//每次打印一个星星for(inti=1;i<=7;i++){…

    2026年4月17日
    5
  • 图像中的掩膜(Mask)是什么

    图像中的掩膜(Mask)是什么在图像处理中 经常会碰到掩膜 Mask 这个词 那么这个词到底是什么意思呢 下面来简单解释一下 1 什么是掩膜首先我们从物理的角度来看看 mask 到底是什么过程 在半导体制造中 许多芯片工艺步骤采用光刻技术 用于这些步骤的图形 底片 称为掩膜 也称作 掩模 其作用是 在硅片上选定的区域中对一个不透明的图形模板遮盖 继而下面的腐蚀或扩散将只影响选定的区域以外的区域 图像掩膜与

    2026年3月26日
    2
  • 欠采样与过采样方法

    欠采样与过采样方法使用 SMOTE 过采样时应先切分训练集和验证集 再对训练集进行过采样 否则将会导致严重的过拟合 https beckernick github io oversampling modeling 使用方法 X train X val y train y val train test split train df predictors train df target

    2026年3月17日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号