Django 错误。不能分配必须是实例

Posted

技术标签:

【中文标题】Django 错误。不能分配必须是实例【英文标题】:Django error. Cannot assign must be an instance 【发布时间】:2016-10-16 19:55:30 【问题描述】:

当我尝试在我的一个表中运行插入时收到以下错误。

不能分配“1”:“Team.department_id”必须是“Department”实例

诚然,我有点不确定我是否正确使用了外键概念。下面给出了我正在尝试运行的插入和来自我的 models.py 的 sn-p。

我想做的是当有人想要创建一个新团队时。他们必须将其附加到一个部门。因此,部门 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)
)

models.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)

【问题讨论】:

【参考方案1】:

你不需要传递部门id,实例本身就足够了。以下应该可以正常工作:

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

请注意,永远不要将您的外来字段命名为 something_id。 something 就足够了。从用户的角度来看,Django 旨在让事情变得简单,_id 后缀意味着您正在考虑数据库层。实际上,如果您将列命名为department,django 会自动为您在数据库中创建department_id 列。事情是这样的,你让 django 创建 department_id_id 这很傻。

【讨论】:

非常感谢。有效。但你的两个解释也确实有助于我的理解。 别忘了添加这行代码:new_team.save()【参考方案2】:

这首先出现在 Google 搜索中,因此为新手提供了替代方案。如果您可以方便地访问 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。

【讨论】:

foreign_key_name_id 正是我正在寻找的。谢谢。

以上是关于Django 错误。不能分配必须是实例的主要内容,如果未能解决你的问题,请参考以下文章

不能分配必须是实例。姜戈

Django REST Framework 更新外键

django - 无法分配外键

Django 3.0:django-notifications 给出错误:“Notification.recipient”必须是“User”实例

值错误。无法分配查询集。它必须是一个实例

尝试在 Django 中的模型表之间建立关系。但是在插入值时出现错误 |外键项必须是一个实例