当前位置: 首页 > news >正文

mysql笔记8(多表查询)

文章目录

  • 1. union联合查询
    • 可能会用到去重操作
  • 2. inner join 内连接
  • 3. left join 左连接
  • 4. right join 右连接
  • 5. cross join 交叉连接
  • 6. natural join 自然连接
    • natural left join 自然左连接
    • natural right join 自然右连接
    • 自然连接的两张表没有同名字段怎么办?
  • 7. using 当两张表字段名都相同时,指定连接字段
  • 8. 哪个连接实用?
  • 9. 内容出处

1. union联合查询

① 联合查询:用union把两个查询语句结合在一起
② 两个查询语句,字段及其数据类型一不一样无所谓,但是字段个数必须一致

在这里插入图片描述

可能会用到去重操作

如果两张表查询的字段名一样,可能会用到distinct去重操作(但是从下面的结果来看,union联合好像自动去重了)
在这里插入图片描述
在这里插入图片描述

2. inner join 内连接

select 字段名,字段名 from 主表 inner join 从表 inner join 从表 on 主表.公共字段=从表.公共字段=从表.公共字段
作用:联合查询
注意:一定要确认主从关系、建立公共字段。可以不使用外键
举例理解(score里的stuId来自student表里id):
在这里插入图片描述
在这里插入图片描述
(上述score表里没有jerry的成绩(ta缺考了),所以联合查询的结果也没ta)
在这里插入图片描述
(三张表联合查询)

3. left join 左连接

以左表为基准
怎么理解?
在这里插入图片描述
在这里插入图片描述
以左边为基准,就算右边那张表里没有2号学生的信息,查询结果依然显示2号学生

4. right join 右连接

以右表为基准
怎么理解?
在这里插入图片描述
在这里插入图片描述
以右边为基准,就算左边那张表里没有学号为12的学生信息,查询结果依然显示12号学生

5. cross join 交叉连接

select 字段名 from 表名 cross 表名;
默认返回一个笛卡尔积
在这里插入图片描述
加上where 表名.公共字段=表名.公共字段后,返回值类似于内连接
在这里插入图片描述

6. natural join 自然连接

① natural join其实默认是自然内连接,根据同名字段连接两张表。
② 好处:不用写两边公共的字段名,但是必须保证两边公共字段名一致
在这里插入图片描述

natural left join 自然左连接

在这里插入图片描述

natural right join 自然右连接

在这里插入图片描述

自然连接的两张表没有同名字段怎么办?

返回笛卡尔积
在这里插入图片描述

7. using 当两张表字段名都相同时,指定连接字段

情境:t1和t3有两个公共字段 id 和 name,这两张表自然连接会产生什么结果?-- 返回一张空表
在这里插入图片描述
怎么办?
在这里插入图片描述

8. 哪个连接实用?

        出于对代码可读性的考虑,基本不会用到自然连接和using

9. 内容出处

mysql

http://www.lryc.cn/news/440863.html

相关文章:

  • typescript-tsconfig文件解释
  • 所有用贪心的算法和所有用动态规划(dp)的算法合集
  • 论文阅读 | 基于流模型和可逆噪声层的鲁棒水印框架(AAAI 2023)
  • 上线跨境电商商城的步骤
  • Python基础(七)——PyEcharts数据分析(面向对象版)
  • 滚雪球学SpringCloud[5.1讲]: Spring Cloud Config详解
  • Unity常用随机数算法
  • dial unix /var/run/docker.sock: connect: permission denied
  • Prompt提示词技巧
  • 滑动窗口(6)_找到字符串中所有字母异位词
  • 【无标题】rocket
  • Maven国内镜像(四种)
  • Linux环境中如何快速修改 JAR 包中的配置文件
  • java高频面试题(2024最新)
  • WEB 编程:使用富文本编辑器 Quill 配合 WebBroker 后端
  • 新书出版,大陆首本NestJS图书《NestJS全栈开发解析:快速上手与实践》
  • 面试题:react、vue中的key有什么作用?(key的内部原理)
  • 基于python+django+vue的外卖管理系统
  • 初始分布式系统和Redis特点(
  • 计算机毕业设计 家电销售展示平台的设计与实现 Java实战项目 附源码+文档+视频讲解
  • Android RecyclerView 缓存机制深度解析与面试题
  • 管道缺陷检测系统源码分享
  • python定时发送邮件的功能如何实现自动化?
  • 工业机器人9公里远距离图传模块,无人机低延迟高清视界,跨过距离限制
  • IEEE-754 32位十六进制数 转换为十进制浮点数
  • XSS跨站脚本攻击及防护
  • 利用ClasserLoader来实现jar包加载并调用里面的方法
  • 【VUE】快速上手
  • 在 Docker 中部署无头 Chrome:在 Browserless 中运行
  • Meta-Learning数学原理