欢迎投稿

今日深度:

MYSQL关联关系查询方式,

MYSQL关联关系查询方式,


目录
  • MYSQL关联关系查询
    • 关联关系查询
    • 这个查询做了以下几件事
  • MySQL自关联查询
    • 总结

      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='广州市';

      总结

      以上为个人经验,希望能给大家一个参考,也希望大家多多支持PHP之友。

      您可能感兴趣的文章:
      • mysql数据库您要的常见日期查询方法总结
      • MySQL查询不区分大小写的两种解决方式
      • MySQL可直接使用的查询表的列信息(实现方案)
      • MySQL不使用子查询的原因及优化案例
      • Python中使用pymysql连接MySQL数据库进行数据查询
      • MYSQL中的简单查询

      www.htsjk.Com true http://www.htsjk.com/Mysql/48647.html NewsArticle MYSQL关联关系查询方式, 目录 MYSQL关联关系查询 关联关系查询 这个查询做了以下几件事 MySQL自关联查询 总结 MYSQL关联关系查询 关联关系查询 首先,让我们回顾一下你的原始查询:...
      评论暂时关闭