0

我有以下型号:

class Vote(models.Model):
    cmt = models.ForeignKey(Comment)
    user = models.ForeignKey(User)
    vote_type = models.SmallIntegerField(default=0) # vote_type is +1 for upvote & -1 for downvote

class Comment(models.Model):
    uuid = models.CharField(max_length=40, default='random')
    user = models.OneToOneField(User, primary_key=True) # ForeignKey('User')
    text = models.CharField(max_length=300, null=True)
    votes = models.ManyToManyField(User, through='Vote', related_name='votes_table')

如果我没有使用through关键字,我可以在 Comment 对象的投票字段中添加一个元素(具有 uuid of id),如下所示:Comment.objects.get(uuid=id).votes.add(some_user) 但这在这里不起作用,因为我必须为表vote_type中的每个条目存储一个comments_votes. 如何才能做到这一点?

4

1 回答 1

2

只需按照文档中的说明Vote创建实例:

Vote.objects.create(cmt=Comment.objects.get(uuid=id),
                    user=some_user, vote_type=1)
于 2015-05-13T14:30:03.103 回答