一句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)

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

相关推荐
葫芦和十三6 小时前
图解 MongoDB 23|两地三中心:跨可用区部署怎么扛机房故障
后端·mongodb·agent
勇哥java实战分享8 小时前
PaddleOCR 太慢?我换成 RapidOCR 后,速度直接起飞
后端
苏三说技术13 小时前
LangChain4j 和 LangGraph4j,哪个更好?
后端
ServBay14 小时前
7 个AI开发中真正用得上的 MCP Server,配合Claude Code食用效果更佳
后端·claude·mcp
妙码生花14 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十五):优化细节、网络请求封装
前端·后端·ai编程
用户67570498850215 小时前
Go 语言里判断字符串为空,90% 的人都写错了!
后端·go
用户67570498850215 小时前
Go 进阶必修:90% 的人都没用对的“表驱动法”
后端·go
小兔崽子去哪了15 小时前
Java 生成二维码解决方案
java·后端
苍何15 小时前
懂事的 Agent 已经开始自己看屏幕干活了,效率起飞!
后端