Monday, July 5, 2021

How do I return a queryset of all items (X) ManyToMany related to model class (Y) and include values for (Y) in the same result in each item X

I have the following two model classes:

```
class Property(models.Model):
    """Represents property class model"""
    serial_no = models.CharField(unique=True,max_length=255,blank=True,null=True)
    map_no = models.CharField(max_length=255,blank=True,null=True)
    lr_no =  models.CharField(max_length=255,blank=True,null=True)
    locality =  models.CharField(max_length=255,blank=True,null=True)
```

```
class PropertyObjection(models.Model):
    """Represents property objection class. This has properties that have been objected"""
    objector_name = models.CharField(max_length=255,null=True, blank=True)
    objection_no = models.CharField(max_length=255,null=True, blank=True)
    properties =  models.ManyToManyField(Property,blank=True)
    ratable_owner = models.BooleanField(null=True,blank=True)
    ratable_relation = models.CharField(max_length=50,null=True, blank=True)
```
Which is the most effective way to get all properties that have been objected using the `PropertyObjection` class. One other thing to note is that each property should have values for `objection_no`, `ratable_owner` and `ratable_relation` values. 

The expected result should look something like this:
```
[
    {
    'objector_name': "Angela Rudolf",
    'serial_no': "5603883",
    'map_no': "238",
    'lr_no': "234/R",
    'locality': "Nairobi",
    'objection_no': "pv876646",
    'ratable_owner': True,
    'ratable_relation': "N/A"
   }
]
```

I attempted this implementation but its not the most effective way to do so considering when data eventually grows (I tried this when I have more than 5000 records and the request takes long to return a response. I'd like to use the ORM methods to effectively populate the required queryset.


```
class ObjectUsvAPIView(generics.ListAPIView):
    permission_classes = (permissions.IsAuthenticated,)
    queryset = PropertyObjection.objects.all()
    pagination_class = PageNumberPagination


    def get_queryset(self):
        """
        This view should return a list of all the properties objected.
        """

        
        qs = PropertyObjection.objects.prefetch_related('properties')


        poplulated_list = (
            {   
                "id":item.id, 
                "property": property,
                "ratable_owner": item.ratable_owner,
                "ratable_relation":  item.ratable_relation,
                "objector_name": item.objector_name

                }
            
            
            for item in qs   for property in item.properties.all()
                

        )
   

        return list(poplulated_list)
```

--
You received this message because you are subscribed to the Google Groups "Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to django-users+unsubscribe@googlegroups.com.
To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/45fa5d47-5e51-4773-a7c4-53b4886faa24n%40googlegroups.com.

No comments:

Post a Comment