0
点赞
收藏
分享

微信扫一扫

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

小猪肥 07-22 21:00 阅读 26

🎬 数据库中的“红娘”

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

  • 一个是房子表(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:只要“配得上”的

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:我全都要!

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

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

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)

SELECT h.title, l.phone
FROM houses h
INNER JOIN landlords l
ON h.landlord_id = l.landlord_id;

  1. 哪些房源没有绑定房东?(LEFT JOIN + WHERE)

SELECT h.title
FROM houses h
LEFT JOIN landlords l
ON h.landlord_id = l.landlord_id
WHERE l.landlord_id IS NULL;

  1. 查询每个预的用户、预时间和房源标题

SELECT a.user_name, a.time, h.title
FROM appointments a
JOIN houses h
ON a.house_id = h.house_id;

举报

相关推荐

0 条评论