如何使用 GORM 對具有不同名稱的字段引用執(zhí)行連接查詢,如下所示: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個贊
您可以使用“連接”來執(zhí)行此操作
https://gorm.io/docs/query.html#Joins
您提供的查詢應使用這種聯(lián)接完成:
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 “外國密鑰”和“引用”來執(zhí)行此操作
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)
- 1 回答
- 0 關注
- 189 瀏覽
添加回答
舉報
0/150
提交
取消