当前位置: 代码网 > it编程>数据库>Mysql > MYSQL关联关系查询方式

MYSQL关联关系查询方式

2025年02月13日 Mysql 我要评论
mysql关联关系查询关联关系查询首先,让我们回顾一下你的原始查询:select u.*, d.id as aid, d.name, d.pro, d.city, d.country, d.detai

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;

这个查询做了以下几件事

  1. tb_user 表中选择所有列(u.*)。
  2. 使用内连接(inner join)将 tb_user 表与 tb_address 表关联起来,条件是 tb_user 表的 id 列等于 tb_address 表的 user_id 列。
  3. tb_address 表中选择特定的列,并为某些列指定别名(如 d.id as aid)。
  4. 使用左外连接(left join)将结果集与 tb_role_user 表关联起来,条件是 tb_role_user 表的 user_id 列等于 tb_user 表的 id 列。
  5. 再使用左外连接将上一步的结果集与 tb_role 表关联起来,条件是 tb_role 表的 id 列等于 tb_role_user 表的 role_id 列。
  6. 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='广州市';

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com