6👍
✅
First problem: joining unrelated models
I’m assuming that your Model1
and Model2
are not related, otherwise you’d be able to use Django’s related objects interface. Here are two approaches you could take:
-
Use
extra
and a SQL subquery:Model1.objects.extra(where = ['field in (SELECT field from myapp_model2 WHERE ...)'])
Subqueries are not handled very efficiently in some databases (notably MySQL) so this is probably not as good as #2 below.
-
Use a raw SQL query:
Model1.objects.raw('''SELECT * from myapp_model1 INNER JOIN myapp_model2 ON myapp_model1.field = myapp_model2.field AND ...''')
Second problem: enumerating the result
Two approaches:
-
You can enumerate a query set in Python using the built-in
enumerate
function:enumerate(Model1.objects.all())
-
You can use the technique described in this answer to do the enumeration in MySQL. Something like this:
Model1.objects.raw('''SELECT *, @row := @row + 1 AS row FROM myapp_model1 JOIN (SELECT @row := 0) rowtable INNER JOIN myapp_model2 ON myapp_model1.field = myapp_model2.field AND ...''')
Source:stackexchange.com