ValueError - 无法分配:必须是一个实例

问题描述 投票:0回答:4

当我尝试在其中一个表中运行插入操作时,出现以下错误。

无法分配“1”:“Team.department_id”必须是“Department”实例

不可否认,我有点不确定我是否正确使用了外键概念。下面给出了我尝试运行的插入内容和 models.py 中的片段。

我想做的是当有人想要创建一个新团队时。他们必须将其附加到一个部门。因此,部门 ID 应该位于两组表中。

new_team = Team(
    nickname = team_name,
    employee_id = employee_id,
    department_id = int(Department.objects.get(
                        password = password,
                        department_name = department_name
                        ).department_id))

模型.py

class Department(models.Model):  
    department_id = models.AutoField(auto_created=True,
                                     primary_key=True,
                                     default=1)  
    department_name = models.CharField(max_length=60)
    head_id = models.CharField(max_length=30)
    password = models.CharField(max_length=128)


class Team(models.Model):  
    team_id = models.AutoField(primary_key=True)
    department_id = models.ForeignKey('Department',
                                       related_name = 'Department_id')
    employee_id = models.CharField(max_length=30)
    nickname = models.CharField(max_length=60)
    team_image = models.ImageField(upload_to=get_image_path,
                                   blank=True, null=True)
python django model foreign-keys
4个回答
75
投票

不需要传递部门id,实例本身就足够了。

以下应该可以正常工作:

new_team = Team(
    nickname = team_name,
    employee_id = employee_id,
    department_id = Department.objects.get(password = password,
                                           department_name = department_name))

请注意:永远不要命名你的外来字段something_id。

某事就足够了。 Django 旨在从用户的角度使事情变得简单,而

_id
后缀意味着您正在考虑数据库层。事实上,如果您将列命名为
department
,django 会自动在数据库中为您创建
department_id
列。

事情就是这样,你让 Django 创建

department_id_id
这是相当愚蠢的。


13
投票

这首先出现在谷歌搜索中,因此为新手提供了另一种选择。如果您可以方便地访问 id 并且不想进行其他查询,您也可以这样做:

new_team = Team(
    nickname = team_name,
    employee_id = employee_id,
    department_id_id = Department.objects.get(password = password, department_name = department_name).department_id
)

简而言之,

{foreign_key_name}_id
如果你想直接分配id的话。


0
投票

@munsu 答案的不同变体。如果你已经有了国外字段的id。

department_id = 2; #the department id for the new team

new_team = Team(
    nickname = team_name,
    employee_id = employee_id,
    department_id = Department(id=department_id)
)

new_team.save()

# but
new_team.department_id.id # 2 
new_team.department_id.department_name # None you cannot access any other fields 

我不知道这是否对任何情况都有用,但就是这样。 :)


0
投票

就我而言,这是一个错字。

X.objects.filter(y__zfield=z_obj).

这里 zfield 的名字实际上是

zField
大写
F

© www.soinside.com 2019 - 2024. All rights reserved.