🎬 数据库中的"红娘"
想象你是个租房平台程序员,数据库里有两个表:
- 一个是房子表(
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 取别名更简洁,写得顺手好维护。
🛠 小练习
-
查询所有房源及其对应的房东电话(INNER JOIN)
sqlSELECT h.title, l.phone FROM houses h INNER JOIN landlords l ON h.landlord_id = l.landlord_id;
-
哪些房源没有绑定房东?(LEFT JOIN + WHERE)
sqlSELECT h.title FROM houses h LEFT JOIN landlords l ON h.landlord_id = l.landlord_id WHERE l.landlord_id IS NULL;
-
查询每个预约的用户、预约时间和房源标题
sqlSELECT a.user_name, a.time, h.title FROM appointments a JOIN houses h ON a.house_id = h.house_id;