I added a new row to my model that assigns the recent project to the page where I can turn on some charts but if I hit the save button I get this error message that I can't figure out why:
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>
Thank you very much in advance!
CodePudding user response:
projekt
is a string that contains a number, not a Projekt
model object, which is necessary.
You can however assign to the projekt_id
field:
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
)
If you make a ForeignKey
named foo
, then you can "talk" with that field through foo
, or foo_id
where foo_id
takes the value of the column referred to by the ForeignKey
.
CodePudding user response:
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()
Whenever you update or create anything in the table contains foreign Key you need to pass the object of primary key or you can assign primary key directly like projekt_id=projekt.