登录
首页 >  Golang >  Go问答

GORM:如何在查询中处理多个关系?

来源:stackoverflow

时间:2024-02-26 13:27:22 343浏览 收藏

哈喽!大家好,很高兴又见面了,我是golang学习网的一名作者,今天由我给大家带来一篇《GORM:如何在查询中处理多个关系?》,本文主要会讲到等等知识点,希望大家一起学习进步,也欢迎大家关注、点赞、收藏、转发! 下面就一起来看看吧!

问题内容

我需要找到属于具有特定 nameschool 的所有 students

type school struct {
    gorm.model
    students []student
}

type student struct {
    gorm.model
    name string
    schoolid uint 
}

我按照文档尝试了这个,但它没有给我任何东西:

Database.Preload("Students", "name = ?", name).Find(&schools)

如何使用 gorm 实现此目的?


正确答案


preload 方法采用函数作为第二个参数。这是一个例子:

database.Model(&School{}).Preload("Students", func(db *gorm.DB) *gorm.DB {
    return db.Where("studens.name = ?", name)
}).Find(&schools)

今天关于《GORM:如何在查询中处理多个关系?》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>