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

如何使用 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_id

tickets.create_user = 没有外键的users.user_id


犯罪嫌疑人X
浏览 168回答 1
1回答

烙印99

您可以使用“连接”来执行此操作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-Keyhttps://gorm.io/docs/has_many.html#Override-Referencestype Ticket struct {    TicketId int64 `gorm:"primaryKey"`    CreateUser int64}type User struct {    UserId  int64    `gorm:"primaryKey"`    Tickets []Ticket `gorm:"foreignKey:CreateUser;references:UserId"`}那么您应该能够查询具有此类票证的用户var users []Userdb.Joins("Tickets").Find(&users)
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go