Merge pull request #773 from SchrodingersGat/moar-speed-fix-plz

Reduce company list from 100 queries to 4 queries
This commit is contained in:
Oliver 2020-05-02 15:41:39 +10:00 committed by GitHub
commit 0b2c6cfd70
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 30 additions and 3 deletions

View File

@ -32,6 +32,13 @@ class CompanyList(generics.ListCreateAPIView):
serializer_class = CompanySerializer serializer_class = CompanySerializer
queryset = Company.objects.all() queryset = Company.objects.all()
def get_queryset(self):
queryset = super().get_queryset()
queryset = CompanySerializer.annotate_queryset(queryset)
return queryset
permission_classes = [ permission_classes = [
permissions.IsAuthenticated, permissions.IsAuthenticated,
@ -67,6 +74,13 @@ class CompanyDetail(generics.RetrieveUpdateDestroyAPIView):
queryset = Company.objects.all() queryset = Company.objects.all()
serializer_class = CompanySerializer serializer_class = CompanySerializer
def get_queryset(self):
queryset = super().get_queryset()
queryset = CompanySerializer.annotate_queryset(queryset)
return queryset
permission_classes = [ permission_classes = [
permissions.IsAuthenticated, permissions.IsAuthenticated,

View File

@ -4,6 +4,8 @@ JSON serializers for Company app
from rest_framework import serializers from rest_framework import serializers
from django.db.models import Count
from .models import Company from .models import Company
from .models import SupplierPart, SupplierPriceBreak from .models import SupplierPart, SupplierPriceBreak
@ -33,11 +35,21 @@ class CompanyBriefSerializer(InvenTreeModelSerializer):
class CompanySerializer(InvenTreeModelSerializer): class CompanySerializer(InvenTreeModelSerializer):
""" Serializer for Company object (full detail) """ """ Serializer for Company object (full detail) """
url = serializers.CharField(source='get_absolute_url', read_only=True) @staticmethod
part_count = serializers.CharField(read_only=True) def annotate_queryset(queryset):
return queryset.annotate(
parts_supplied=Count('supplied_parts'),
parts_manufactured=Count('manufactured_parts')
)
url = serializers.CharField(source='get_absolute_url', read_only=True)
image = serializers.CharField(source='get_thumbnail_url', read_only=True) image = serializers.CharField(source='get_thumbnail_url', read_only=True)
parts_supplied = serializers.IntegerField(read_only=True)
parts_manufactured = serializers.IntegerField(read_only=True)
class Meta: class Meta:
model = Company model = Company
fields = [ fields = [
@ -57,7 +69,8 @@ class CompanySerializer(InvenTreeModelSerializer):
'is_manufacturer', 'is_manufacturer',
'is_supplier', 'is_supplier',
'notes', 'notes',
'part_count' 'parts_supplied',
'parts_manufactured',
] ]