【MySQL】多表查询

【MySQL】多表查询首先,为了方便说明问题,创建两个表emp(雇员信息)和dept(雇员部门信息),其数据如下:在之前的博客中,我们分享了单表查询的方法,但是在实际应用中,我们要查的数据很可能不在同一个表中,而是来自于不同的表。多表查询如果不加任何条件,得到的结果称为笛卡尔积。例如,查找雇员名、雇员工资以及部门所在的名字。可以发现,结果是这样的,从第一个表中选出第一条记录,和第二个表中的所有所有记…

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

首先,为了方便说明问题,创建两个表emp(雇员信息)和dept(雇员部门信息),其数据如下:
这里写图片描述
在之前的博客中,我们分享了单表查询的方法,但是在实际应用中,我们要查的数据很可能不在同一个表中,而是来自于不同的表。多表查询如果不加任何条件,得到的结果称为笛卡尔积。
例如,查找雇员名、雇员工资以及部门所在的名字。
这里写图片描述
可以发现,结果是这样的,从第一个表中选出第一条记录,和第二个表中的所有所有记录进行组合,然后再从第一个表中取出第二条记录,和第二张表的所有记录进行组合,这样的结果是没有实际意义的。我们需要的是emp.deptno = dept.deptno字段的记录。
这里写图片描述

自连接

自连接是指在同一张表连接查询

  1. 显示员工FORD的上级领导的名字
    这里写图片描述

子查询

子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询。

单行子查询:子查询的查询结果只有一行
  1. 显示和SMITH同一部门的员工
    这里写图片描述
多行子查询(in ,all, any):返回多条记录的子查询
  1. 查询和10好部门的工作相同的官员的名字、工作、工资、部门号,但是不包括10号自己的信息
    这里写图片描述
  2. 显示工资比部门编号为30的所有员工的工资高的员工的姓名、工资和部门号
    这里写图片描述
  3. 显示工资比部门编号为30的任意员工的工资高的员工的姓名、工资和部门号
    这里写图片描述
多列子查询:查询返回多个列数据的子查询语句
  1. 查询和SMITH的部门和岗位完全相同的雇员,不含SMITH本人
    这里写图片描述
from子句中使用子查询
  1. 显示高于自己部门的平均工资的员工信息
    这里写图片描述
  2. 查找每个部门工资最高的人的ename, job, sal
    这里写图片描述
    3.显示每个部门的信息(部门名、编号、地址)和人员数量
    这里写图片描述
    这里有两种方法可以使用,但是经验证,当数据非常多的时候from子查询的效率是高于多表查询的。
删除表中的重复记录

已知一个表tt中有重复的数据

  1. 创建一张空表tmp_tt,空表的结构与表tt的结构相同;create table tmp_tt like tt;
  2. 将tt表进行distinct,将数据导入空表中;insert into tmp_tt select distinct * from tt;
  3. 删除原表ttdrop table tt;
  4. 将tmp_tt改名为ttalter table tmp_tt rename tt;
合并查询

  在实际应用中,为了合并多个select的执行结果,可以使用union,union all集合操作符

  1. union操作符用于取得两个结果的并集,并再自动去掉重复行
    查找工资大于2500和职位Manger的人
    这里写图片描述
    2. union all 与union类似,但是不会自动去重
    例如:与or类似
    这里写图片描述

外键

  外键定义主表和从表的关系,外键约束主要是定义在从表上,主表必须是有主键或者唯一键。当定义外键后,要求外键列数据必须在主表列存在或者为NULL。
  
  例如:创建一个主表class,从表stu
  这里写图片描述
  这里写图片描述
  由上图,我们可以知道主键不能为null,但是外键可以为null,同时不能存在外键有的数据而主表中不存在。

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • C语言二进制与十进制之间的转换[通俗易懂]

    C语言二进制与十进制之间的转换[通俗易懂]二进制与十进制之间的转换#include<stdio.h>voidconvert(intn){ if(n>1) { convert(n/2);} printf("%d",n%2);}intmain(){ int

    2022年10月18日
    4
  • oracle number类型 p、s参数说明[通俗易懂]

    oracle number类型 p、s参数说明[通俗易懂] oraclenumber类型采用科学计数法表示,p表示有效数字的个数,s表示精度;如果定义字段类型为number(p,s)则该字段所能表示的最大正数是(10p-1)*10-s最小负数-(10p-1)*10-s;所有该范围之间的数字均可根据精度四舍五入后插入该字段;否则将会报错。  

    2022年7月24日
    8
  • 广东电信 DNS 设置更改

    广东电信 DNS 设置更改因为未知原因(真的不知中国电信为何如此,有空打10000问问),原先广东电信用户可以使用的DNS服务器,如202.96.128.68202.96.128.110,不能使用了。因此,如果你的ADSL是使用路由方式共享上网的,并且手动设置了DNS服务器地址为以上ip,将会出现上不了网的情况。这就需要把DNS服务器地址更…

    2022年7月11日
    43
  • java基础—java.io.FileNotFoundException: D:\\AAA(拒绝访问。)

    java.io.FileNotFoundException: D:\AAA(拒绝访问)

    2022年2月24日
    66
  • win11频繁更新,关闭win11恶意软件删除工具补丁更新

    win11频繁更新,关闭win11恶意软件删除工具补丁更新win11补丁更新主要包含4部分:第一部分功能更新,涉及Windows功能bug、新增的功能等;第二部分质量更新,涉及安全风险的更新;第三部分驱动更新,涉及厂商等提交给微软的驱动,进行更新;第四部分其它更新,目前主要发现的是,恶意软件删除工具更新。恶意软件删除工具,如果有第三方安全软件的话,这个补丁意义不大,并且恶意的标准是微软自家定义的,就看你是否接受微软自带的杀毒软件,如果用可以更新,如果不用该补丁频率高,无必要。关闭“恶意软件删除更新”,只需要用dism++关闭,步骤如下:

    2022年6月24日
    37
  • Mybatis源码分析_struts源码

    Mybatis源码分析_struts源码Mybatis提供了一个简单的逻辑分页类RowBounds,其原理类似于在内存中做了一个分页,不是数据库层面的分页,性能不算好,谨慎使用一.RowBounds源码分析1RowBounds源码:/***Copyright2009-2017theoriginalauthororauthors.**LicensedundertheApacheLicense,Version2.0(the”License”);*youmaynot.

    2022年9月22日
    4

发表回复

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

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