一句mysql复杂查询搞崩一个壮汉

我说的这个壮汉就是我自己啦,哈哈哈哈哈😊

之前的复杂查询基本是用gorm自带的关联查询preload()方法,把数据模型关联关系绑定清楚,傻瓜式的preload就搞定,复杂点的数据就硬写,大力出奇迹

像这种经典的多对多关联查询,一句话也就搞定了,db.model(&User).preload("Roles.Permissions"),返回的数据直接丢给前端,让前端自己提取数据,去重,重组成权限数组,毕竟前段写着方便。(前端也是我,我对前端更熟),就这样rbac模块功能也出来了。前端动态路由也实现了,看上去还让我给纸糊出一个系统的基础。

但是,自己知道,内功不深厚,早晚都得补,所以恶补mysql和gorm,过程很痛苦,但终究是弄出来了,

记录一下爬坡过程

1,查用户列表时候,把用户的角色信息查出来,放在一个数组里,并且去重,没有角色返回[]
csharp 复制代码
type UserListVO struct {
    ID       uint                     `json:"id"`
    Username string                   `json:"username"`
    Phone    string                   `json:"phone"`
    Email    string                   `json:"email"`
    Roles    []map[string]interface{} `json:"roles" gorm:"serializer:json"`
}
var list []UserListVO
database.DB.Raw(`
    select u.id,u.username,
       if(
         count(r.id) =0,'[]',json_arrayagg(json_object('id',r.id,'name',r.name))
       ) as roles
    from users u
    left join user_roles ur on ur.user_id=u.id
    left join roles r on r.id=ur.role_id
    group by u.id
`).Scan(&list)
response.Success(c, list)
2,查角色数据时,把他绑定的权限查出来,放在一个数组里,并且去重,没有数据返回[]
csharp 复制代码
type RoleListVO struct {
    ID          uint                     `json:"id"`
    Name        string                   `json:"name"`
    Code        string                   `json:"code"`
    Permissions []map[string]interface{} `json:"permissions" gorm:"serializer:json"`
}
var list []RoleListVO
database.DB.Raw(`
    select r.*,
        if(
        count(p.id)=0,'[]',json_arrayagg(json_object('id',p.id,'name',p.name))
        ) as permissions
    from roles r
    left join role_permissions rp on rp.role_id=r.id
    left join permissions p on p.id=rp.permission_id
    group by r.id
`).Scan(&list)
response.Success(c, list)
3,查用户时候把用户的权限查出来,放一个数组里,并且去重,没有数据返回[]
csharp 复制代码
type UserListVO struct {
    ID          uint                     `json:"id"`
    Username    string                   `json:"username"`
    Phone       string                   `json:"phone"`
    Email       string                   `json:"email"`
    Permissions []map[string]interface{} `json:"permissionsArr" gorm:"serializer:json"`
}
var list []UserListVO
database.DB.Raw(`
    select u.*,
        if(
        count(p.id) = 0,'[]',json_arrayagg(json_object('id',p.id,'name',p.name))
        ) as permissions
    from users u
    left join (
        select distinct ur.user_id,rp.permission_id
        from user_roles as ur
        left join role_permissions as rp on ur.role_id=rp.role_id
    ) as up on up.user_id=u.id
    left join permissions as p on p.id=up.permission_id
    group by u.id
`).Scan(&list)
response.Success(c, list)

费了我不少脑细胞,我看到了那扇门透出的光,就是那扇全栈架构师的大门

相关推荐
武子康3 分钟前
Java-07 深入浅出 MyBatis数据库一对多关系模型实战:表结构设计与查询实现
java·后端
花椒技术1 小时前
企业内部 Agent 落地复盘:Gateway、Skill 和二次确认如何串起受控业务执行
后端·agent·ai编程
我是一颗柠檬3 小时前
【MySQL全面教学】MySQL事务与ACID Day9(2026年)
数据库·后端·mysql
枕星而眠3 小时前
数据结构八大排序详解(一):四大简单排序
c语言·数据结构·c++·后端
IT_陈寒3 小时前
React useEffect闭包陷阱差点把我整失业了
前端·人工智能·后端
苍何3 小时前
爆肝两周,我把 Codex 最全实战指南开源了
后端
bug菌4 小时前
【SpringBoot 3.x 第254节】夯爆了,数据库访问性能优化实战详解!
数据库·spring boot·后端
xxl大卡4 小时前
MySQL的执行流程
数据库·mysql
Rust研习社4 小时前
从碎片化到标准化:cargo-bp 如何重构 Rust 开发逻辑
后端·rust·编程语言
chicheese4 小时前
MySQL优化实践:选错JOIN 驱动表,性能相差几十倍
数据库·mysql