当我尝试在其中一个表中运行插入时出现以下错误。
无法分配" 1":" Team.department_id"必须是"部门"实例
不可否认,我有点不确定我是否正确使用了外键概念。我试图运行的插入程序和我的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)
)
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)
在这里输入代码
答案 0 :(得分:19)
您不需要传递部门ID,实例本身就足够了。以下应该可以正常工作:
new_team = Team(
nickname = team_name,
employee_id = employee_id,
department_id = Department.objects.get(password = password, department_name = department_name)
)
请注意,不要将您的外国字段命名为某事 _id。 某事就足够了。 Django旨在从用户的角度简化事务,而_id
后缀意味着您正在考虑数据库层。实际上,如果您为列department
命名,django将自动为您创建数据库中的department_id
列。事情的方式,你正在制作django创建department_id_id
,这是相当愚蠢的。
答案 1 :(得分:1)
这首先出现在 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。