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

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

按屬性篩選

按屬性篩選

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

3 回答

?
海綿寶寶撒

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

不。Django過濾器在數據庫級別運行,生成SQL。要基于Python屬性進行過濾,您必須將對象加載到Python中以評估該屬性-到那時,您已經完成了加載該對象的所有工作。


查看完整回答
反對 回復 2019-10-11
?
慕慕森

TA貢獻1856條經驗 獲得超17個贊

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


它不會被過濾@property,因為F在將對象帶入python之前會與數據庫進行對話。但是仍然把它作為答案,因為我想要按屬性過濾的原因實際上是想通過對兩個不同字段進行簡單算術的結果來過濾對象。


因此,類似以下內容:


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

然后對所有對象進行列表理解。


查看完整回答
反對 回復 2019-10-11
  • 3 回答
  • 0 關注
  • 958 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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