私はこのようなモデルを持っています:
class Thing(models.Model):
property1 = models.IntegerField()
property2 = models.IntegerField()
property3 = models.IntegerField()
class Subthing(models.Model):
subproperty = models.IntegerField()
thing = modelsForeignkey(Thing)
main = models.BooleanField()
各フィルターの形式が {'type':something, 'value':x} であるフィルターのリストを渡す関数があります。この関数は、すべてのフィルターをまとめて ANDing した一連の結果を返す必要があります。
final_q = Q()
for filter in filters:
q = None
if filter['type'] =='thing-property1':
q = Q(property1=filter['value'])
elif filter['type'] =='thing-property2':
q = Q(property2=filter['value'])
elif filter['type'] =='thing-property2':
q = Q(property3=filter['value'])
if q:
final_q = final_q & q
return Thing.objects.filter(final_q).distinct()
各 Subthing にはブール プロパティ「main」があります。すべてのモノには、main==True のサブシングが 1 つだけあります。
Subthing wheremain==True
とSubthing を持つすべての Thing を返すフィルターを追加する必要があります。subproperty==filter['value']
Q
構築中のオブジェクトの一部としてこれを行うことはできますか? そうでない場合はどうすればいいですか?新しいフィルターの前に取得するクエリセットは非常に大きくなる可能性があるため、結果のループを伴わない方法が必要です。