我想要实现的目标:
http://sqlfiddle.com/#!5/dccc4/5
数据库计划:
CREATE TABLE Table1
(
idTable1 integer primary key
);
CREATE TABLE Table2
(
idTable1 integer,
user_id integer,
num integer
);
INSERT INTO Table1 (idTable1) VALUES (1);
INSERT INTO Table1 (idTable1) VALUES (2);
INSERT INTO Table2 (idTable1, user_id, num) VALUES (1, 11, 111);
INSERT INTO Table2 (idTable1, user_id, num) VALUES (1, 22, 222);
原始SQL查询:
SELECT T1.idTable1,
IFNULL(T2.num, 0) num
FROM Table1 T1
LEFT JOIN Table2 T2
ON T1.idTable1 = T2.idTable1
AND T2.user_id = 11
WHERE T1.idTable1 = 1
生成的QuerySet :
| idTable1 | num |
|----------|-----|
| 1 | 111 |
是否可以使用Django ORM进行编码?
更新
模型是:
class Table1(models.Model):
# ...
class Table2(models.Model):
user = models.ForeignKey(User)
table1 = models.ForeignKey(Table1)
num = models.IntegerField(null=True)
答案 0 :(得分:1)
这样的事情:
from django.db.models import Q, Value as V
from django.db.models.functions import Coalesce
objects = Table1.objects.filter(
Q(table2__isnull=True) | Q(table2__user=11),
id=1
).annotate(
num=Coalesce('table2__num', V(0))
).values('id', 'num')
这是LEFT JOIN
,但我不知道Django是否可以在AND
之类的查询中构建... LEFT JOIN ... ON ... AND ... WHERE
部分。在这种情况下,最终结果是相同的(我希望)。