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ì)象的所有工作。

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)行列表理解。
添加回答
舉報(bào)