为了账号安全,请及时绑定邮箱和手机立即绑定

如何使用 GORM 对具有不同名称的字段引用执行连接查询

如何使用 GORM 对具有不同名称的字段引用执行连接查询

Go
犯罪嫌疑人X 2022-10-04 20:05:53
如何使用 GORM 对具有不同名称的字段引用执行连接查询,如下所示:SELECT * FROM tickets JOIN ticket_details ON tickets.ticket_id = ticket_details.ticket_id JOIN users ON tickets.create_user = users.user_id JOIN employees ON users.employee_id = employees.employee_idtickets.create_user = 没有外键的users.user_id
查看完整描述

1 回答

?
烙印99

TA贡献1829条经验 获得超13个赞

您可以使用“连接”来执行此操作

https://gorm.io/docs/query.html#Joins

您提供的查询应使用这种联接完成:

db.Model(...).Joins("JOIN ticket_details ON tickets.ticket_id = ticket_details.ticket_id").Joins("JOIN users ON tickets.create_user = users.user_id").Joins("JOIN employees ON users.employee_id = employees.employee_id")...

如果要在模型中设置工单和用户之间的关系

我假设关系是用户“有很多”票证

并且模型用户/票证的 ID 为 int64

然后,您可以通过设置 gorm “外国密钥”和“引用”来执行此操作

https://gorm.io/docs/has_many.html#Override-Foreign-Key

https://gorm.io/docs/has_many.html#Override-References

type Ticket struct {

    TicketId int64 `gorm:"primaryKey"`

    CreateUser int64

}


type User struct {

    UserId  int64    `gorm:"primaryKey"`

    Tickets []Ticket `gorm:"foreignKey:CreateUser;references:UserId"`

}

那么您应该能够查询具有此类票证的用户


var users []User

db.Joins("Tickets").Find(&users)


查看完整回答
反对 回复 2022-10-04
  • 1 回答
  • 0 关注
  • 167 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信