IT评测·应用市场-qidao123.com

标题: MySQL学习笔记-多表查询(上) [打印本页]

作者: 麻花痒    时间: 2023-3-2 02:59
标题: MySQL学习笔记-多表查询(上)
多表查询(上)

一. 多表关系

在实际应用中,根据需求,设计的表结构之间存在联系,联系一般分为以下三种
1. 一对多(多对一)

案例:部门与员工的关系,一个部门对应多个员工,一个员工对应一个部门。


2. 多对多

案例:学生与课程的关系,一个学生可以选修多门课程,一门课程也可以供多个学生选择。


3. 一对一

案例:用户与用户信息的关系。
多用于单表拆分,将一张表的基础字段放在一张表中,其他详情字段放在另一张表中,以提升效率。


二. 多表查询

多表查询:从多张表中查询数据

1. 连接查询

1.1 内连接

内连接:查询A、B交集部分数据
  1. # 隐式内连接
  2. select {字段列表} from {表1},{表2} where {条件};
  3. # 显式内连接
  4. select {字段列表} from {表1} [inner] join {表2} on {连接条件};
复制代码
  1. select {字段列表} from {表1} {别名1},{表2} {别名2} where {条件};
复制代码
1.2 外连接

外连接:左(右)外连接:查询左表(右表)所有数据,以及两张表交集部分数据
  1. # 左外连接
  2. select {字段列表} from {表1} left [outer] join {表2} on {条件};
  3. # 右外连接
  4. select {字段列表} from {表1} right [outer] join {表2} on {条件};
复制代码
1.3 自连接

自连接:当前表与自身的连接查询,自连接必须使用表别名
案例:在一张表里有员工信息,包括直属领导id(领导也在员工表内),查询员工与对应的领导,用自连接。

  1. # 内连接语法,外连接类似
  2. select {字段列表} from {表A} {别名A} join {表A} {别名B} on {条件};
复制代码

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 IT评测·应用市场-qidao123.com (https://dis.qidao123.com/) Powered by Discuz! X3.4