My models:
class BaseModel(models.Model):
my_field = models.CharField(max_length=250)
class Meta:
abstract = True
class ModelA(BaseModel):
a_field = models.CharField(max_length=250)
class ModelB(BaseModel):
def some_function(self):
return 'some result'
Now i want to perform filtering on queryset, where queryset consists of ModelA.objects.all() and ModelB.objects.all().
I tried:
queryset = chain(ModelA.objects.all(), ModelB.objects.all())
And then:
queryset.filter(my_field='some_string')
But i receive following error:
'itertools.chain' object has no attribute 'filter'
How can i concatenate QuerySets of these two models into one and perform filtering based only on BaseModel fields?