我正在尝试创建一个django数据库,记录我所有的漫画购买,我遇到了一些问题.我试图模拟一个漫画问题与从事它的艺术家之间的关系.
一个漫画问题有一个或多个艺术家正在研究这个问题,一个艺术家将处理一个以上的问题.此外,艺术家的角色与他们在漫画创作者(在该问题上的所有工作),作家(写剧本),抽屉(绘制完整的漫画),铅笔,墨水,颜色或文字,并且可能有几位艺术家担任某个角色.
这给了我一个数据库模型,如: 
然后我将其转换为以下Django模型.由于我需要关于关系的其他数据,我相信我必须使用一个单独的类来处理这种关系,并保留额外的关系
class Artist(models.Model):
name = models.CharField(max_length = 100)
def __unicode__(self):
return self.name
class ComicIssue(models.Model):
issue_number = models.IntegerField()
title = models.TextField()
artists = models.ManyToManyField(Artist, through='IssueArtist')
def __unicode__(self):
return u'issue = %s, %s' % (self.issue_number, self.title)
class IssueArtist(models.Model):
roles = ( (0, "--------"),
(1, "Creator"),
(2, "Writer"),
(3, "Drawer"),
(4, "Pencils"),
(5, "Inks"),
(6, "Colours"),
(7, "Text"),
)
artist = models.ForeignKey(Artist)
issue = models.ForeignKey(ComicIssue)
role = models.IntegerField(choices = roles)
Run Code Online (Sandbox Code Playgroud)
我的问题是:
1)这似乎是一种正确的建模方法吗?
2)如果我不使用该through='IssueArtist'功能,我可以使用该artists.add()功能添加关系.如果我使用它,我会收到错误'ManyRelatedManager' object has …