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

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

Gorm WHERE 子句不適用于預加載數據

Gorm WHERE 子句不適用于預加載數據

Go
慕娘9325324 2022-04-20 19:29:19
下面的這個查詢有效,該where子句之所以有效,是因為它使用了ResourceUsage結構中的值,但我希望能夠做這樣的事情,其中where子句使用ResourceMetadata結構中的值。db.Preload("ResourceMetadata").Where("resource_type = ?", resourceType).Where("timestamp BETWEEN ? AND ?", start, end).Limit(10).Find(&resourceUsage)但它拋出異常:2019-12-03 11:06:12] 錯誤 1054:“where 子句”中的未知列“resource_type”代碼:// ResourceUsage describes the storage model for resource-usagetype ResourceUsage struct {    ID               int64             `json:"-"`    DetailsID        int64             `json:"details_id"`    ResourceMetadata *ResourceMetadata `gorm:"foreignkey:DetailsID;association_foreignkey:ID"`    MeasuredType     string            `json:"measured_type"`    Quantity         float64           `json:"quantity"`    Timestamp        int64             `json:"timestamp"`}// ResourceMetadata describes the storage model for resource-usagetype ResourceMetadata struct {    ID                  int64  `json:"-"`    ResourceUUID        string `json:"resource_uuid"`    ResourceName        string `json:"resource_name"`    ResourceDisplayName string `json:"resource_display_name"`    ResourceType        string `json:"resource_type"`}db.Preload("ResourceMetadata").Where("timestamp BETWEEN ? AND ?", start, end).Limit(10).Find(&resourceUsage)
查看完整描述

1 回答

?
蝴蝶刀刀

TA貢獻1801條經驗 獲得超8個贊

可以使用 JOIN 嗎?


    resourceUsages := []ResourceUsage{}

    if err := db.Joins("JOIN resource_metadata ON resource_metadata.id=details_id").

        Where("resource_metadata.resource_type = ? AND timestamp BETWEEN ? AND ?", resourceType, start, end).

        Preload("ResourceMetadata").Limit(10).

        Find(&resourceUsages).Error; err != nil {

        // ... handle error ...

    }


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

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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