2012-10-30 45 views
10

我有这样的错误:Django。此函数的无效关键字参数。多对多

'人' 是这个函数

class Passage(models.Model): 
    name= models.CharField(max_length = 255) 
    who = models.ForeignKey(UserProfil) 

class UserPassage(models.Model): 
    passage = models.ForeignKey(Passage) 
    people = models.ManyToManyField(UserProfil, null=True) 

class UserProfil(models.Model): 
    user = models.OneToOneField(User) 
    name = models.CharField(max_length=50) 

我尝试了无效的关键字参数:

def join(request): 
    user = request.user 
    user_profil = UserProfil.objects.get(user=user) 
    passage = Passage.objects.get(id=2) 
    #line with error 
    up = UserPassage.objects.create(people= user_profil, passage=passage) 
    return render_to_response('thanks.html') 

怎样一个人准确地做到这一点?谢谢!

回答

20

您需要保存/创建对象,然后才能添加ManyToMany关系:

up = UserPassage.objects.create(passage=passage) 
up.people.add(user_profil) 

ManyToMany关系未保存到你的表列。在这里阅读第一个回复了很好的解释:

Django ManyToMany field is not created in model

@DanielRoseman: Because a ManyToMany isn't a field, at least not one that exists as a database column. It's a relationship with a linking table. You'll find that a table named myapp_teacher_subjects has been created, with foreign keys to both teacher and subjects.

相关问题