mysql关联关系查询
关联关系查询
首先,让我们回顾一下你的原始查询:
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;
mysql自关联查询
定义表areas,结构如下
id
atitle
pid
因为省没有所属的省份,所以可以填写为null
城市所属的省份pid,填写省所对应的编号id
这就是自关联,表中的某一列,关联了这个表中的另外一列,但是它们的业务逻辑含义是不一样的,城市信息的pid引用的是省信息的id
在这个表中,结构不变,可以添加区县、乡镇街道、村社区等信息
- 创建areas表的语句如下:
create table areas( id int primary key, atitle varchar(20), pid int, foreign key(pid) references areas(id) );
查询一共有多少个省
- 查询省的名称为“山西省”的所有城市
select city.* from areas as city inner join areas as province on city.pid=province.id where province.atitle='山西省';
- 查询市的名称为“广州市”的所有区县
select dis.*,dis2.* from areas as dis inner join areas as city on city.id=dis.pid left join areas as dis2 on dis.id=dis2.pid where city.atitle='广州市';
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
发表评论