关联关系查询
首先,让我们回顾一下你的原始查询:
SELECT u.*, d.id AS aid, d.name, d.pro, d.city, d.country, d.detail, d.tel AS atel, r.name AS roleName
FROM tb_user u
INNER JOIN tb_address d ON u.id = d.user_id
LEFT JOIN tb_role_user ur ON ur.user_id = u.id
LEFT JOIN tb_role r ON r.id = ur.role_id;
这个查询做了以下几件事:
- 从
tb_user表中选择所有列(u.*)。 - 使用内连接(
INNER JOIN)将tb_user表与tb_address表关联起来,条件是tb_user表的id列等于tb_address表的user_id列。 - 从
tb_address表中选择特定的列,并为某些列指定别名(如d.id AS aid)。 - 使用左外连接(
LEFT JOIN)将结果集与tb_role_user表关联起来,条件是tb_role_user表的user_id列等于tb_user表的id列。 - 再使用左外连接将上一步的结果集与
tb_role表关联起来,条件是tb_role表的id列等于tb_role_user表的role_id列。 - 从
tb_role表中选择name列,并为其指定别名roleName。
现在,我将对这个查询进行扩写,包括一些额外的解释和可能的优化:
-- 选择用户及其关联的地址、角色信息
SELECT -- 用户表的所有列u.id AS userId, u.username, u.email, u.password, u.created_at, u.updated_at,-- 地址表的特定列及别名d.id AS addressId, d.name AS addressName, d.province AS pro, d.city, d.country, d.detail AS addressDetail, d.tel AS addressTel,-- 角色名的别名r.name AS roleName
FROM tb_user u-- 内连接:只选择有地址的用户INNER JOIN tb_address d ON u.id = d.user_id-- 左外连接:选择所有用户及其可能的角色关联LEFT JOIN tb_role_user ur ON u.id = ur.user_id-- 再左外连接:选择所有角色关联及其角色名LEFT JOIN tb_role r ON ur.role_id = r.id;
