登录
首页 >  Golang >  Go问答

如何使用 GORM 获得明显的结果

来源:stackoverflow

时间:2024-04-19 18:03:20 411浏览 收藏

哈喽!今天心血来潮给大家带来了《如何使用 GORM 获得明显的结果》,想必大家应该对Golang都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习Golang,千万别错过这篇文章~希望能帮助到你!

问题内容

在 go 中,我编写了一个查询来提供所有数据,但我只想获取 products.id 和 client.id 不同的数据。 我可以写什么明喻查询?

res := find.Model(&domain.Clients{}).
    Select ("products.id product_id, products.name product_name,"+
        " clients.id id, clients.name name, clients.logo, clients.address, "+
        "clients.business_id, clients.num_of_employee, clients.email, clients.sns_link, clients.phone").
    Joins("LEFT JOIN company_interests ON company_interests.client_id = clients.id").
    Joins("LEFT JOIN products ON products.id = company_interests.product_id").
    Where("products.id = ? ", productId).Find(&resp)

正确答案


在go中,当我写“select distinct”然后休息查询时,它在go中无效。所以,我想到了使用“group by”编写查询。在go中,“group by”语法可以通过“group”语法来使用。所以,最后下面的查询对我来说效果很好。

res := find.Model(&domain.Clients{}).
    Select ("products.id product_id, products.name product_name,"+
        " clients.id id, clients.name name, clients.logo, clients.address, "+
        "clients.business_id, clients.num_of_employee, clients.email, clients.sns_link, clients.phone").
    Joins("LEFT JOIN company_interests ON company_interests.client_id = clients.id").
    Joins("LEFT JOIN products ON products.id = company_interests.product_id").
    Where("products.id = ? ", productId).
    Group("company_interests.client_id, company_interests.product_id" ).Find(&resp)

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何使用 GORM 获得明显的结果》文章吧,也可关注golang学习网公众号了解相关技术文章。

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