第6篇:《JOIN 是红娘,帮你配对多张表!》

🎬 数据库中的"红娘"

想象你是个租房平台程序员,数据库里有两个表:

  • 一个是房子表(houses):记录房源信息
  • 一个是房东表(landlords):记录每个房东的联系方式

这时你老板说:

"小王,快搞一个页面,显示每套房子的标题 + 房东姓名 + 手机号。"

如果这两个信息在不同的表里怎么办?

这时候就要用 SQL 中的"配对大师":JOIN


1️⃣ 表结构示意

🏠 表1:房源表 houses

house_id title price landlord_id
1 精装一房 1800 101
2 电梯两房 2500 102
3 合租三房 2000 103

👤 表2:房东表 landlords

landlord_id name phone
101 张先生 13888888888
102 李姐 13999999999
104 王叔 13777777777

2️⃣ INNER JOIN:只要"配得上"的

sql 复制代码
SELECT h.title, h.price, l.name, l.phone
FROM houses h
INNER JOIN landlords l
ON h.landlord_id = l.landlord_id;

解读

  • INNER JOIN:只保留能"成功配对"的行
  • ON:配对的依据(关联键)
    🟡 上例中房东 103 没出现在 landlords 表,结果只会返回前两套房子。

3️⃣ LEFT JOIN:我全都要!

sql 复制代码
SELECT h.title, h.price, l.name, l.phone
FROM houses h
LEFT JOIN landlords l
ON h.landlord_id = l.landlord_id;

解读

  • LEFT JOIN:以左表(houses)为主
  • 没配对上的也保留,右边字段是 NULL
    📌 常用于:查"孤儿记录"、看谁没有绑定信息

4️⃣ 真实场景:用户预约看房表

你又有了两个表:

👀 表3:预约表 appointments

id user_name house_id time
1 小李 1 2024-05-01
2 小张 2 2024-05-03
3 小李 3 2024-05-05

查询每个用户预约了哪套房子

sql 复制代码
SELECT a.user_name, a.time, h.title, h.price
FROM appointments a
JOIN houses h
ON a.house_id = h.house_id;

🧠 JOIN 口诀

JOIN 来配对,ON 把关系连,

INNER 配得上才留,LEFT 主表全都看。

多表关系靠 ID,名字不同别慌乱,

AS 取别名更简洁,写得顺手好维护。


🛠 小练习

  1. 查询所有房源及其对应的房东电话(INNER JOIN)

    sql 复制代码
    SELECT h.title, l.phone
    FROM houses h
    INNER JOIN landlords l
    ON h.landlord_id = l.landlord_id;
  2. 哪些房源没有绑定房东?(LEFT JOIN + WHERE)

    sql 复制代码
    SELECT h.title
    FROM houses h
    LEFT JOIN landlords l
    ON h.landlord_id = l.landlord_id
    WHERE l.landlord_id IS NULL;
  3. 查询每个预约的用户、预约时间和房源标题

    sql 复制代码
    SELECT a.user_name, a.time, h.title
    FROM appointments a
    JOIN houses h
    ON a.house_id = h.house_id;
相关推荐
计算机毕设vx_bysj686912 小时前
【免费领源码】77196基于java的手机银行app管理系统的设计与实现 计算机毕业设计项目推荐上万套实战教程JAVA,node.js,C++、python、大屏数据可视化
java·mysql·智能手机·课程设计
吴声子夜歌12 小时前
ES6——正则的扩展详解
前端·mysql·es6
xixingzhe212 小时前
Mysql统计空间增量
数据库·mysql
程序员萌萌12 小时前
Java之mysql实战讲解(三):聚簇索引与非聚簇索引
java·mysql·聚簇索引
cozil14 小时前
记录mysql创建数据库未指定字符集引发的问题及解决方法
数据库·mysql
AC赳赳老秦14 小时前
OpenClaw数据库高效操作指南:MySQL/PostgreSQL批量处理与数据迁移实战
大数据·数据库·mysql·elasticsearch·postgresql·deepseek·openclaw
ego.iblacat14 小时前
Python 连接 MySQL 数据库
数据库·python·mysql
阿丰资源16 小时前
SpringBoot+MySQL+MyBatis-Plus+Vue前后端分离仓库管理系统 (附资料)
spring boot·mysql·mybatis
阿华田51216 小时前
MySQL性能优化大全
数据库·mysql·性能优化
被摘下的星星17 小时前
MySQL 别名使用规则详解
数据库·mysql