谁能帮我解决以下场景?
我有 3 张桌子,如下所示。 1和2是我的数据表。
并且 3 与 1 和 2 保持关系。
1.Qa table
-------------
|ID | QA |
-------------
|1 |qa1 |
|2 |qa2 |
|3 |qa3 |
-------------
a field of my Qa model
tags = select2.fields.ManyToManyField(Tag, blank=True, verbose_name='Tag')
2.Tag table
-------------
|ID | Tag |
-------------
|1 |tag1 |
|2 |tag2 |
|3 |tag3 |
-------------
3.qa tag relation
---------------------
|ID |QA_ID |Tag_ID |
---------------------
|1 |1 |2 |
|2 |1 |3 |
|3 |2 |1 |
|4 |3 |1 |
|5 |3 |2 |
|6 |3 |3 |
---------------------
Edit
qa model
class Qa(models.Model):
question_text = models.CharField(max_length=1000, verbose_name='Question')
tags = select2.fields.ManyToManyField(Tag, blank=True, verbose_name='Tag')
"""
And some more fields.
"""
def __str__(self):
return self.question_text
class Meta:
ordering = ("id",)
verbose_name = 'QA data'
标签模型
class Tag(models.Model):
tag_text = models.CharField(max_length=30, unique=True, verbose_name='Tag')
def __str__(self):
return self.tag_text
class Meta:
verbose_name = 'QA Tag'
※我没有qa_tag型号
如果我删除标签列表(从上面的 2.标签表),它会重定向到确认表。它显示带有一些变量名称的列表,如下所示
- Tag: tag1
- Qa-标签关系:Qa_tags 对象
- Qa-标签关系:Qa_tags 对象
- Tag: tag2
- Tag: tag3
- Qa-标签关系:Qa_tags 对象
- Qa-标签关系:Qa_tags 对象
- Qa-标签关系:Qa_tags 对象
我真正期望的是(用户可读的信息)
- Tag: tag1
- Tag: tag2
- Tag: tag3
- Qa-标签关系:qa1
- Qa-标签关系:qa2
- Qa-标签关系:qa3
我不明白为什么会发生这种情况以及如何解决它。任何帮助将非常感激。
Edit2:
在丹尼尔·罗斯曼的回答之后,我尝试创建一个自己的模型来处理多对多关系
class Qa_Tag(models.Model):
def __str__(self):
return self.tag.tag_text
qa 模型更改如下
class Qa(models.Model):
....
tags = select2.fields.ManyToManyField(Tag, blank=True, through = 'Qa_Tag', verbose_name='Tag')
....
它显示删除时的值。但我必须在 admin.py 中注册 Qa_Tag,并且我可以分配关系的唯一方法是通过 Qa_Tag 视图。
现在我知道原因是没有__str__()
我的 Qa_Tag 表的方法,但仍然无法弄清楚如何在不中断任何内容的情况下为生成的 qa_tag 表编写模型类。