登录
首页 >  Golang >  Go问答

Gorm 对预加载字段的计数

来源:stackoverflow

时间:2024-04-12 23:48:35 213浏览 收藏

珍惜时间,勤奋学习!今天给大家带来《Gorm 对预加载字段的计数》,正文内容主要涉及到等等,如果你正在学习Golang,或者是对Golang有疑问,欢迎大家关注我!后面我会持续更新相关内容的,希望都能帮到正在学习的大家!

问题内容

我使用 postgres 和 go lang 和 echo 框架作为我的基础,并使用 gorm 来构建我的数据库查询。

这是我的个人资料模型,

type profile struct {
  gorm.model
  invoicecount     uint      `gorm:"-"`
  companyname      string    `gorm:"size:255"`
  companynumber    string    `gorm:"size:10"`
  companyvatnumber string    `gorm:"size:10"`
  dateadded        time.time `gorm:"type:date"`
  primaryemail     string    `gorm:"size:255"`
  isactive         bool
  invoice []*invoice `gorm:"foreignkey:profile_fk" json:",omitempty"`
  address []*address `gorm:"foreignkey:profile_fk" json:",omitempty"`
}

这链接到我的发票模型,我正在尝试在预加载时进行计数。我添加了 invoicecount uint 可以将计数添加到此模型中。

这就是我所绑定的,

dbCon().
  Preload("Invoice", func(db *gorm.DB) *gorm.DB {   
    return db.Count(&profile)
  }).
  Find(&profile).
  RecordNotFound()

但是,除了这个不起作用之外,它还返回以下错误:(pq:“”“”处或附近的零长度分隔标识符)

我试图通过一个简单的查询来做到这一点,但这错了吗?我是否需要循环遍历我的所有配置文件并为每个配置文件添加计数?或者通过子选择下拉到原始 sql 查询?

谢谢


解决方案


我已经构建了这个原始 sql 查询,

dbConn().
    Raw("SELECT p.*, count(i.id) as invoice_count FROM profiles p left join invoices i on i.profile_fk = p.id group by p.id").
    Scan(&result)

到这里,我们也就讲完了《Gorm 对预加载字段的计数》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

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