Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/20.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python Django:将外键上的两个表连接到第三个表?_Python_Django - Fatal编程技术网

Python Django:将外键上的两个表连接到第三个表?

Python Django:将外键上的两个表连接到第三个表?,python,django,Python,Django,我有三种型号 A类(型号): ... B类(型号): id=整型字段() a=外键(a) 丙类(型号): id=整型字段() a=外键(a) 我想得到(B.id,C.id)的对,其中B.a==C.a。我如何使用django orm进行连接?django允许您以与使用\uuuu>进行正向查找大致相同的方式进行连接: 它也可以反向工作。要引用“反向”关系,只需使用模型的小写名称 此示例检索至少有一个标题包含“列侬”的条目的所有Blog对象: Blog.objects.filter(条目标题包含cl

我有三种型号

A类(型号):
...
B类(型号):
id=整型字段()
a=外键(a)
丙类(型号):
id=整型字段()
a=外键(a)
我想得到(B.id,C.id)的对,其中B.a==C.a。我如何使用django orm进行连接?

django允许您以与使用
\uuuu>进行正向查找大致相同的方式进行连接:

它也可以反向工作。要引用“反向”关系,只需使用模型的小写名称

此示例检索至少有一个标题包含“列侬”的条目的所有
Blog
对象:

Blog.objects.filter(条目标题包含class='Lennon')

我认为你可以做这样的事情,@Daniel Roseman对你将得到的结果集类型提出警告

ids = B.objects.prefetch_related('a', 'a__c').values_list('id', 'a__c__id')
如果内存可用,与预取相关的功能将有助于提高django旧版本的性能。

对于每个A,可能有许多B和C实例。