第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何使用 GORM 對具有不同名稱的字段引用執(zhí)行連接查詢

如何使用 GORM 對具有不同名稱的字段引用執(zhí)行連接查詢

Go
犯罪嫌疑人X 2022-10-04 20:05:53
如何使用 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)


查看完整回答
反對 回復 2022-10-04
  • 1 回答
  • 0 關注
  • 189 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號