Обновить базу данных из вида - PullRequest
0 голосов
/ 30 мая 2019

View.py

@login_required
def UnosPosudbe(request):
    if request.method == 'GET':
        forma = PosudbaForma()
    elif request.method == 'POST':
        forma = PosudbaForma(request.POST,request.FILES)
        if forma.is_valid():
            #Dohvacanje Kolicine
            kolicinaKnjige = str(forma.cleaned_data['nazivKnjige'])
            IDKnjige = kolicinaKnjige

            kolicinaKnjige = kolicinaKnjige[-1:]
            IDKnjige = IDKnjige[:1]

            unesenaKolicina = forma.cleaned_data['kolicina']
            if(int(kolicinaKnjige)>=unesenaKolicina and unesenaKolicina > 0):
                #update kolicine
                knjiga = Knjiga.objects.get(pk=IDKnjige)
                knjiga.kolicina = int(knjiga.kolicina) - int(unesenaKolicina)
                print(knjiga)
                knjiga_forma = KnjigaForma(request.POST, instance = knjiga)
                knjiga_forma.save() 
                #
                forma.save()
                return redirect('pregledPosudbe')
    return render(request, 'unosPosudbe.html', {'forma':forma})  

Я пытаюсь обновить базу данных с помощью части кода, но постоянно получаю сообщение об ошибке:

knjiga = Knjiga.objects.get(pk=IDKnjige)
                knjiga.kolicina = int(knjiga.kolicina) - int(unesenaKolicina)
                print(knjiga)
                knjiga_forma = KnjigaForma(request.POST, instance = knjiga)
                knjiga_forma.save() 

Ошибка:

ValueError at / UnosPosudbe / Knjiga не удалось изменить, поскольку данные не были проверены.

Я не уверен, что делаю неправильно?

Models.py

class Knjiga(models.Model):
    naziv = models.CharField(null=False, blank=True, max_length=120)
    autor = models.ForeignKey(Autor, on_delete=models.CASCADE, null=True)   
    datumObjave = models.DateField(null=True, blank=False)
    izdanje = models.CharField(null=True, blank=True, max_length=120)
    slika= models.FileField(upload_to='images/', null=True, verbose_name="") #videofile
    kolicina = models.IntegerField(null=False, blank=False)

    def __str__(self):
        return str(self.id) + ', ' +str(self.naziv) + ', ' + str(self.autor) + ', Kolicina:' + str(self.kolicina)

----- ОБНОВЛЕНИЕ ----

Все работает для вышеуказанной проблемы.Но теперь я хочу сделать, когда я удаляю созданную строку, чтобы она возвращала количество обратно в «knjiga.kolicina».

Удаление работает так:

@ login_required def deletePosudbe (request, id):data = Posudba.objects.get (id = id)

IDKnjige = data
kolicinaKnjige = IDKnjige[-1:]
IDKnjige = IDKnjige[:1]

print(kolicinaKnjige)
print(IDKnjige)

data.delete()
return redirect('pregledPosudbe') 

Я получаю сообщение об ошибке:

Ошибка типа в / deletePosudbe / 22 Объект Posudba не может быть подписан

Я пытаюсь сделать то же самое, чтобы получить ID и количество и обновить его обратно.

1 Ответ

1 голос
/ 30 мая 2019

Где проверка KnjigaForma(request.POST, instance=knjiga)?вам это нужно ...

from django.db.models import F
@login_required
def UnosPosudbe(request):
    if request.method == 'GET':
        forma = PosudbaForma()
    elif request.method == 'POST':
        forma = PosudbaForma(request.POST,request.FILES)
        if forma.is_valid():
            #Dohvacanje Kolicine
            kolicinaKnjige = str(forma.cleaned_data['nazivKnjige'])
            IDKnjige = kolicinaKnjige

            kolicinaKnjige = kolicinaKnjige[-1:]
            IDKnjige = IDKnjige[:1]

            unesenaKolicina = forma.cleaned_data['kolicina']
            if(int(kolicinaKnjige)>=unesenaKolicina and unesenaKolicina > 0):
                #update kolicine
                knjiga = Knjiga.objects.get(pk=IDKnjige)
                knjiga.kolicina = int(knjiga.kolicina) - int(unesenaKolicina) # This is better option (Everything happens on the database side. more safe) => knjiga.kolicina = F('kolicina') - int(unesenaKolicina)
                knjiga.save() # add save method here
                print(knjiga)
                knjiga_forma = KnjigaForma(request.POST, instance = knjiga)
                if knjiga_forma.is_valid(): # add this line
                    knjiga_forma.save()
                forma.save()
                return redirect('pregledPosudbe')
    return render(request, 'unosPosudbe.html', {'forma':forma})

и ваш вид удаления

from django.http import HttpResponseNotFound

@login_required
def deletePosudbe(request, id):
    try
        data = Posudba.objects.get(id=id)
    except Posudba.DoesNotExist:
        return HttpResponseNotFound('Resource does not exist!')
    else:
        print('data => ', data)
        print('data.__dict__ => ', data.__dict__)
        data.delete() # you can delete safe way now.
    return redirect('pregledPosudbe') 

Надеюсь, этот код будет работать.Удачи.

...