「MySQL」多表查询

多表关系

  1. 一对多(多对一)
    • 实现:在多的一方建立外键,指向一的一方的主键
  2. 多对多
    • 实现:: 建立第三张中间表,中间表至少包含两个外键,分别关联两方主键
  3. 一对一
    • 实现:在任意一方加入外键,关联另外一方的主键,并且设置外键为唯一的(UNIQUE)

多表查询概述

  1. 分类
    • 连接查询
      • 内连接:相当于查询 A、B 交集部分数据
      • 外连接
        • 左外连接:查询左表所有数据,以及两张表交集部分数据
        • 右外连接:查询右表所有数据,以及两张表交集部分数据
      • 自连接:当前表与自身的连接查询,自连接必须使用表别名
    • 子查询

内连接

  1. 隐式内连接:SELECT 字段列表 FROM 表1 , 表2 WHERE 条件 ... ;
  2. 显式内连接:SELECT 字段列表 FROM 表1 [ INNER ] JOIN 表2 ON 连接条件 ... ;
  3. 一旦为表起了别名,就不能再使用表名来指定对应的字段了,此时只能够使用别名来指定字段

外连接

  1. 左外连接:SELECT 字段列表 FROM 表1 LEFT [ OUTER ] JOIN 表2 ON 条件 ... ;
  2. 右外连接:SELECT 字段列表 FROM 表1 RIGHT [ OUTER ] JOIN 表2 ON 条件 ... ;
  3. 左外连接和右外连接是可以相互替换的,只需要在连接查询时 SQL 中调节表结构的先后顺序

自连接

  1. 语法:SELECT 字段列表 FROM 表A 别名A JOIN 表A 别名B ON 条件 ... ;
  2. 在自连接查询中,必须要为表起别名

联合查询

  1. union all 查询出来的结果,仅仅进行简单的合并,并未去重
  2. union 联合查询,会对查询出来的结果进行去重处理
  3. 字段列表数量和类型要一致
sql 复制代码
SELECT 字段列表 FROM 表A ... 
UNION [ ALL ] 
SELECT 字段列表 FROM 表B ....;

子查询

  1. 语法:SELECT * FROM t1 WHERE column1 = ( SELECT column1 FROM t2 );

  2. 分类

    1. 根据子查询结果分类
      • 标量子查询(子查询结果为单个值)
      • 列子查询(子查询结果为一列)
      • 行子查询(子查询结果为一行)
      • 表子查询(子查询结果为多行多列)
    2. 根据子查询位置分类
      • where 之后
      • from 之后
      • select 之后
  3. 标量子查询

    • 子查询返回的结果是单个值(数字、字符串、日期等)
    • 常用的操作符:= <> > >= < <=
  4. 列子查询

    • 子查询返回的结果是一列(可以是多行)

    • 常用操作符

      操作符 描述
      IN 在指定的集合范围之内,多选一
      NOT IN 不在指定的集合范围之内
      ANY 子查询返回列表中,有任意一个满足即可
      SOME 与 ANY 等同,使用 SOME 的地方都可以使用 ANY
      ALL 子查询返回列表的所有值都必须满足
  5. 行子查询

    • 子查询返回的结果是一行(可以是多列)
    • 常用的操作符:= 、<> 、IN 、NOT IN
  6. 表子查询

    • 子查询返回的结果是多行多列
    • 常用的操作符:IN
相关推荐
睡觉的时候不会困3 小时前
Redis 主从复制详解:原理、配置与主从切换实战
数据库·redis·bootstrap
程序员的世界你不懂5 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
自学也学好编程5 小时前
【数据库】Redis详解:内存数据库与缓存之王
数据库·redis
福赖5 小时前
《MySQL基础——用户管理》
mysql·用户管理
JAVA不会写6 小时前
在Mybatis plus中如何使用自定义Sql
数据库·sql
IT 小阿姨(数据库)6 小时前
PgSQL监控死元组和自动清理状态的SQL语句执行报错ERROR: division by zero原因分析和解决方法
linux·运维·数据库·sql·postgresql·centos
ChinaRainbowSea6 小时前
7. LangChain4j + 记忆缓存详细说明
java·数据库·redis·后端·缓存·langchain·ai编程
小马学嵌入式~7 小时前
嵌入式 SQLite 数据库开发笔记
linux·c语言·数据库·笔记·sql·学习·sqlite
Java小白程序员7 小时前
MyBatis基础到高级实践:全方位指南(中)
数据库·mybatis
Monly218 小时前
人大金仓:merge sql error, dbType null, druid-1.2.20
数据库·sql