Python中文
首页
教程
问答
标签
搜索
登录
注册
多多关系中的中介模型字段过滤
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我想在组织之间建立一种友谊关系。我在<code>Organisation</code>模型中添加了一个<code>connected_organisations</code>字段:</p> <pre><code>class Organisation(models.Model): ... connected_organisations = models.ManyToManyField('self', related_name='organisations_connected', through='Connection', through_fields=('requester', 'requestee'), symmetrical=False, blank=True) </code></pre> <p>然后我创建了<code>Connection</code>作为中介模型:</p> <pre><code>class Connection(models.Model): requester = models.ForeignKey(Organisation, related_name='requester', null=True, on_delete=models.CASCADE) requestee = models.ForeignKey(Organisation, related_name='requestee', null=True, on_delete=models.CASCADE) is_connected = models.BooleanField(default=False) </code></pre> <p><code>is_connected</code>字段表示请求者是否批准了友谊请求,或者请求是否仍然挂起。你知道吗</p> <p>我在<code>org1</code>和<code>org2</code>之间创建一个连接:</p> <pre><code>Connection.objects.create(requester=org1, requestee=org2) </code></pre> <p>我知道我能做到:</p> <p><code>org1.connected_organisations.all()</code></p> <p>这将返回<code>org2</code>,但是我找不到如何通过<code>is_connected</code>字段过滤它们。你知道吗</p> <p>我试过这样的方法:</p> <p><code>Organisation.objects.filter(connected_organisations__requestee=org2, connected_organisations__is_connected=True)</code></p> <p>但我得到了:</p> <blockquote> <p>django.core.exceptions.FieldError: Related Field got invalid lookup: is_connected</p> </blockquote>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>您可以直接使用through模型(在这种情况下我通常会这样做):</p> <pre><code>qs = Connection.objects.filter(requester=org1, requestee=org2, is_connected=True) </code></pre>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
无法使用Django/mongoengine连接到MongoDB(身份验证失败)
10 回答
无法使用Django\u mssql\u后端迁移到外部hos
5 回答
无法使用Django&Python3.4连接到MySql
4 回答
无法使用Django+nginx上载媒体文件
3 回答
无法使用Django1.6导入名称模式
2 回答
无法使用Django1.7和mongodb登录管理站点
7 回答
无法使用Djangoadmin创建项目,进程使用了错误的路径,因为我事先安装了错误的Python
4 回答
无法使用Djangockedi验证CBV中的字段
6 回答
无法使用Djangocketditor上载图像(错误400)
2 回答
无法使用Djangocron进行函数调用
9 回答
无法使用Djangofiler djang上载文件
3 回答
无法使用Djangokronos
8 回答
无法使用Djangomssql provid
6 回答
无法使用Djangomssql连接到带有Django 1.11的MS SQL Server 2016
3 回答
无法使用Djangomssq迁移Django数据库
5 回答
无法使用Djangonox创建用户
7 回答
无法使用Djangopyodb从Django查询SQL Server
10 回答
无法使用Djangopython3ldap连接到ldap
5 回答
无法使用Djangoredis连接到redis
8 回答
无法使用Django中的FK创建新表
7 回答