У меня есть 3 модели, подключенные к одной по внешнему ключу:
class A(models.Model):
name = models.CharField(max_length=20)
class B(models.Model):
a = models.ForeignKey(A, on_delete=models.CASCADE)
amount_b = models.FloatField()
class C(models.Model):
a = models.ForeignKey(A, on_delete=models.CASCADE)
amount_c = models.FloatField()
class D(models.Model):
a = models.ForeignKey(A, on_delete=models.CASCADE)
amount_d = models.FloatField()
И я хочу сделать запрос JOIN на основе внешних ключей, используя Django ORM, чтобы получить сумму каждой суммы.
В SQL я бы сделал что-то вроде:
SELECT
a.name,
b_sum,
c_sum,
d_sum
FROM A AS a
LEFT JOIN (SELECT b.a, sum(amount_b) as b_sum
from B as b
group by b.a) as AB AB.a = a.id
LEFT JOIN (SELECT c.a, sum(amount_c) as c_sum
from C as c
group by a) AS AC ON AC.a = a.id
LEFT JOIN (SELECT d.a, sum(amount_d) as d_sum
from D as d
group by a) AS AD ON AD.a = a.id
WHERE a.name LIKE 'init%'
Но я не нашел ничего подобного в django ORM.