亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

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

Go GORM Preload & Select only items 匹配預加載表條件

Go GORM Preload & Select only items 匹配預加載表條件

Go
斯蒂芬大帝 2022-06-06 15:00:13
我試圖使用 GORM 從父表中僅選擇在相關表中具有匹配條件的項目。type Table1 struct {    gorm.Model    Name string    Email string    Items Table2}type Table2 struct {    gorm.Model    Product string    otherfield string}我想返回將 Table2 中的 Product 設置為特定值的所有 Table1 項目。到目前為止,我得到了 mssql:無法綁定多部分標識符“visits.sign_out_time”。很多。我的命令是var items []Table2db.Debug().Preload("Table2").Where("table2.product = ?", "xxx").Find(&items).GetErrors()不完全確定我哪里出錯了,但無論出于何種原因, .Where() 都無法訪問第二個預加載的表。我該如何使用 GORM 來實現我想要做的事情?
查看完整描述

2 回答

?
翻閱古今

TA貢獻1780條經驗 獲得超5個贊

Where("table2.product = ?", "xxx")無法訪問第二個(預加載)表,因為它Preload不是一個JOINS,它是一個單獨的SELECT查詢。您的代碼創建兩個單獨的查詢,如下所示:


// first query

SELECT * FROM table1 WHERE table2.product = 'xxx';

// second query

SELECT * FROM table2;

為了返回設置為特定值的所有記錄,您必須執行以下操作Table1:ProductTable2


var t1 []Table1

err = db.

Where(`EXISTS(SELECT 1 FROM table2 t2 WHERE t2.product = ? AND table1.id = t2.table1_id)`, productValue).

Find(&t1).Error

請注意,這AND table1.id = t2.table1_id部分只是兩個表如何相關的示例,您可能有不同的關系,您需要相應地修改查詢。


如果您希望 GORMt1.Items使用Table2數據填充 ,請Preload("Items")在上述查詢之前添加。


查看完整回答
1 反對 回復 2022-06-06
?
UYOU

TA貢獻1878條經驗 獲得超4個贊

如果只需要Items,可以直接查詢,Table2無需預加載Table1


var items []Table2

db.Where("product = ?", "xxx").Find(&items).GetErrors()

或者您需要Table1then Join 的所有數據,table2然后使用 where 子句


db.Debug().Joins("JOIN table2 ON table1.id = table2.table1_id")

          .Where("table2.product = ?", "xxxx").Find(&table1data)

在這里我沒有看到任何外鍵Table2加入。你可以添加一個。


type Table2 struct {

    gorm.Model

    Product  string

    Table1ID uint

}


查看完整回答
反對 回復 2022-06-06
  • 2 回答
  • 0 關注
  • 611 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號