Как решить ошибку значения -cannot assign... в Django
Я добавил новую строку в свою модель, которая назначает недавний проект на страницу, где я могу включить некоторые графики, но если я нажму кнопку сохранения, я получу это сообщение об ошибке, которое я не могу понять, почему:
ValueError at /mpa/project_details/1/
Cannot assign "'1'": "ProjectDetailsAdmin.projekt" must be a "Projekt" instance.
views.py
@user_passes_test(lambda u: u.is_superuser)
def project_details(request, projekt_id):
projekt = Projekt.objects.raw('SELECT projekt_id, id FROM stressz_profile WHERE stressz_profile.projekt_id=%s', [projekt_id])
projects_details = Profile.objects.filter(projekt_id=projekt_id)
allprojects = Projekt.objects.all()
... lots of queries here
context = {
...
'projekt': projekt,
'projects_details': projects_details,
'allprojects': allprojects,
...
}
if request.method == 'POST':
projekt = request.POST.get('projekt')
projekt_name = request.POST.get('projekt_name')
r01 = request.POST.get('r01')
szervkult_adm = ProjectDetailsAdmin(projekt=projekt, projekt_name=projekt_name r01=r01)
szervkult_adm.save()
return render(request, 'stressz/project_details.html', context)
models.py
class ProjectDetailsAdmin(models.Model):
def __str__(self):
return str(self.projekt_name)
projekt = models.ForeignKey('Projekt', on_delete=models.CASCADE, default=False, null=True )
projekt_name = models.TextField(max_length=200, null=True )
r01 = models.IntegerField(null=True, blank=True, default=0)
class Projekt(models.Model):
def __str__(self):
return str(self.projekt)
projekt = models.TextField(max_length=150)
html
<div class="container bg-warning my-3">Válaszd ki projektet:
<select class="form-select" id="projekt" name="projekt" aria-label="">
{% for i in allprojects %}
<option>{{ i.id }}</option>
{% endfor %}
</select>
</div>
Заранее большое спасибо!
projekt
- это строка, содержащая число, а не объект модели Projekt
, который необходим.
Однако вы можете присвоить полю projekt_id
следующие значения:
if request.method == 'POST':
projekt = request.POST.get('projekt')
projekt_name = request.POST.get('projekt_name')
r01 = request.POST.get('r01')
szervkult_adm = ProjectDetailsAdmin.objects.create(
projekt_id=projekt,
projekt_name=projekt_name,
r01=r01
)
Если вы создадите ForeignKey
с именем foo
, то вы сможете "общаться" с этим полем через foo
, или foo_id
, где foo_id
принимает значение колонки, на которую ссылается ForeignKey
.
if request.method == 'POST':
projekt = request.POST.get('projekt')
projekt_name = request.POST.get('projekt_name')
r01 = request.POST.get('r01')
szervkult_adm = ProjectDetailsAdmin(projekt_id=projekt,
projekt_name=projekt_name r01=r01)
szervkult_adm.save()
Когда вы обновляете или создаете что-либо в таблице, содержащей внешний ключ, вам нужно передать объект первичного ключа или вы можете назначить первичный ключ напрямую, например projekt_id=projekt.