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

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

按屬性篩選

按屬性篩選

侃侃無極 2019-10-11 10:40:26
是否可以通過模型屬性過濾Django查詢集?我的模型中有一個(gè)方法:@propertydef myproperty(self):    [..]現(xiàn)在我想按此屬性進(jìn)行過濾,例如:MyModel.objects.filter(myproperty=[..])這有可能嗎?
查看完整描述

3 回答

?
海綿寶寶撒

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

不。Django過濾器在數(shù)據(jù)庫級(jí)別運(yùn)行,生成SQL。要基于Python屬性進(jìn)行過濾,您必須將對(duì)象加載到Python中以評(píng)估該屬性-到那時(shí),您已經(jīng)完成了加載該對(duì)象的所有工作。


查看完整回答
反對(duì) 回復(fù) 2019-10-11
?
慕慕森

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

看起來將F()與批注一起使用將是我的解決方案。


它不會(huì)被過濾@property,因?yàn)镕在將對(duì)象帶入python之前會(huì)與數(shù)據(jù)庫進(jìn)行對(duì)話。但是仍然把它作為答案,因?yàn)槲蚁胍磳傩赃^濾的原因?qū)嶋H上是想通過對(duì)兩個(gè)不同字段進(jìn)行簡(jiǎn)單算術(shù)的結(jié)果來過濾對(duì)象。


因此,類似以下內(nèi)容:


companies = Company.objects\

    .annotate(chairs_needed=F('num_employees') - F('num_chairs'))\

    .filter(chairs_needed__lt=4)

而不是將屬性定義為:


@property

def chairs_needed(self):

    return self.num_employees - self.num_chairs

然后對(duì)所有對(duì)象進(jìn)行列表理解。


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

添加回答

舉報(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)