python-带有额外字段的Django ManyToMany字段在两种关系中均不显示
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python-带有额外字段的Django ManyToMany字段在两种关系中均不显示,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1567字,纯文字阅读大概需要3分钟。
内容图文
![python-带有额外字段的Django ManyToMany字段在两种关系中均不显示](/upload/InfoBanner/zyjiaocheng/683/5ef88258605e41e4bbf1f5a3ed6a8574.jpg)
我有一堂课
class Assembly(models.Model):
room = models.ForeignKey("Room", related_name="assemblies")
name = models.CharField(max_length=200)
number = models.IntegerField()
position = models.CharField(max_length=200, blank=True)
components = models.ManyToManyField("material.Component", through="m2m_Assembly_Components")
connections = models.ManyToManyField("Assembly", through="Connection")
category = models.ForeignKey("Category", default=0)
notes = models.TextField(blank=True)
在其自身的实例(连接)之间具有ManyToMany Realtionship.
我使用中间表Connection,以便可以在Assembly的两个实例之间建立用于连接的其他字段.
class Connection(models.Model):
source = models.ForeignKey("Assembly", related_name="source_assembly", null=True)
destination = models.ForeignKey("Assembly", related_name="destination_assembly", null=True)
length = models.IntegerField(null=True, blank=True)
如果我有两个程序集,比如说A和B,然后通过定义一个新的Connection(使用A作为源,B作为目标)来连接它们,我将B作为A的连接(A.connections.all()),但是我不知道不能将A作为B的连接.
如果我不使用中间表,则只需一个models.ManyToManyField(“ Assembly”),我将A作为B的连接,将B作为A的连接.
我这是什么问题
解决方法:
我认为您需要为ManyToManyField指定through_fields参数.
当Django自动生成直通模型时,它会知道其中的两个ForeignKey中的哪一个对应于关系的“本地”端,而哪一个是“远程”端.但是,当您指定自定义中介模型时,这会变得更加困难. Django可能只将中介模型中的第一个ForeignKey指向正确的目标模型,在两种情况下,这恰好都是源代码(尽管我不确定情况是否如此,如果确实如此,则可能是一个错误).
尝试查看是否使用through_fields =(‘source’,’destination’)有帮助.
内容总结
以上是互联网集市为您收集整理的python-带有额外字段的Django ManyToMany字段在两种关系中均不显示全部内容,希望文章能够帮你解决python-带有额外字段的Django ManyToMany字段在两种关系中均不显示所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。