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

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

有條件地構(gòu)建查詢并保持公共部分以不同方式執(zhí)行

有條件地構(gòu)建查詢并保持公共部分以不同方式執(zhí)行

Go
回首憶惘然 2022-10-10 19:11:23
試圖弄清楚如何使用 gorm 有條件地構(gòu)建查詢,保存公共查詢部分并執(zhí)行它。假設(shè)我正在查詢?nèi)缦抡n程列表。common_query_part := app.GetDB(). // <= this returns *gorm.DB        Model(&models.Course{}).        Where("status=?", models.CourseStatusPublished) //models.CourseStatusPublished is a constant現(xiàn)在我想獲取已發(fā)布課程的列表。并得到它的計(jì)數(shù)。所以我就這樣試了。published_course_count := *common_query_part然后是課程列表   result := common_query_part.                 Offset(offset).                 Limit(limit).                 find(&courses)          if result.Error !=nil {         //handle error       } 并為計(jì)數(shù)result = published_course_count.Count(&total)       if result.Error !=nil {             //handle error           } 第一部分完美運(yùn)行。但是查詢的第二部分不起作用,甚至不會(huì)產(chǎn)生任何錯(cuò)誤。在這種情況下我該怎么辦?常見(jiàn)的查詢部分可能龐大而復(fù)雜。因此,為了獲得計(jì)數(shù)而再次重寫(xiě)它可能容易出錯(cuò)。那么有沒(méi)有辦法讓我保留公共查詢部分并有時(shí)為已發(fā)布的課程執(zhí)行它..有時(shí)為已發(fā)布的課程計(jì)數(shù)?
查看完整描述

1 回答

?
慕的地6264312

TA貢獻(xiàn)1817條經(jīng)驗(yàn) 獲得超6個(gè)贊

我不相信 GORM 打算讓您以這種方式重用您的查詢。很難明確地說(shuō),但它很可能不起作用,因?yàn)槿杂幸恍顟B(tài)是共享的。


這:按結(jié)構(gòu)published_course_count := *common_query_part的值進(jìn)行復(fù)制gorm.DB,但如果該結(jié)構(gòu)包含任何指針(它確實(shí)包含),那么這些指針也會(huì)被復(fù)制,從而導(dǎo)致兩個(gè)單獨(dú)的結(jié)構(gòu)具有指向相同對(duì)象的指針,因此仍然被“鏈接”。您需要一個(gè)專用的克隆功能,該功能確實(shí)存在于gorm中但未公開(kāi)。


我建議您將通用部分的生成放在一個(gè)函數(shù)中并調(diào)用它兩次,這樣您就不必復(fù)制粘貼相同的查詢。


func common_query_part() *gorm.DB {

    return app.GetDB().

        Model(&models.Course{}).

        Where("status=?", models.CourseStatusPublished)

}


查看完整回答
反對(duì) 回復(fù) 2022-10-10
  • 1 回答
  • 0 關(guān)注
  • 91 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)