如何使用 GORM 执行具有不同名称的字段引用的连接查询
how to perform a join query with field references with different names using 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 没有外键
您可以使用“连接”
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")...
如果您想在模型中设置票证和用户之间的关系
我假设关系是用户“有很多”票
模型的IDUser/Ticket是int64
然后你可以通过设置 gorm“foreignKey”和“references”来做到这一点
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)
如何使用 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 没有外键
您可以使用“连接”
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")...
如果您想在模型中设置票证和用户之间的关系
我假设关系是用户“有很多”票
模型的IDUser/Ticket是int64
然后你可以通过设置 gorm“foreignKey”和“references”来做到这一点
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)