mirror of
https://github.com/i701/sarlink-portal-api.git
synced 2025-10-06 20:11:35 +00:00
fix(views): optimize database queries to solve N+1 problems 🔨🐛
This commit is contained in:
@@ -36,9 +36,9 @@ class DeviceSerializer(serializers.ModelSerializer):
|
||||
|
||||
def get_pending_payment_id(self, obj):
|
||||
unpaid_payment = (
|
||||
Payment.objects.filter(devices=obj, paid=False)
|
||||
.order_by("-created_at")
|
||||
.first()
|
||||
obj.unpaid_payments[0]
|
||||
if hasattr(obj, "unpaid_payments") and obj.unpaid_payments
|
||||
else None
|
||||
)
|
||||
return unpaid_payment.id if unpaid_payment else None
|
||||
|
||||
@@ -63,9 +63,9 @@ class AdminDeviceSerializer(serializers.ModelSerializer):
|
||||
|
||||
def get_pending_payment_id(self, obj):
|
||||
unpaid_payment = (
|
||||
Payment.objects.filter(devices=obj, paid=False)
|
||||
.order_by("-created_at")
|
||||
.first()
|
||||
obj.unpaid_payments[0]
|
||||
if hasattr(obj, "unpaid_payments") and obj.unpaid_payments
|
||||
else None
|
||||
)
|
||||
return unpaid_payment.id if unpaid_payment else None
|
||||
|
||||
|
Reference in New Issue
Block a user