【发布时间】:2017-08-07 04:58:44
【问题描述】:
大家好,当您尝试在数据库中保存表单的日期时遇到问题:
django.db.utils.OperationalError: 表 app_avaliacao 没有列 命名为 nota
是的,我运行 manage.py makemigrations 和 manage.py migrate,我尝试删除文件夹 migrations 并运行一次命令再次,但错误仍在继续......
所以,这里有我的代码:
models.py:
from django.db import models
from jsonfield import JSONField
from site_.settings import MEDIA_ROOT
from django.core.validators import MaxValueValidator
class Criterio(models.Model):
label = models.CharField(max_length=100)
def __str__(self):
return self.label
class Candidato(models.Model):
name = models.CharField(max_length=100)
e_mail = models.EmailField(max_length=100, default = '')
github = models.URLField(default = '')
linkedin = models.URLField(max_length=100, default = '')
cover_letter = models.TextField(default = '')
Ensino_superior = models.BooleanField(default = False)
med = models.IntegerField(default = 0)
#talvez tenha que alterrar essa linha
docfile = models.FileField(upload_to='/home/douglas/Documentos/Django/my-second-blog/site_/media', null=True, blank=True)
def __str__(self):
return self.name
class Avaliacao(models.Model):
candidato = models.ForeignKey(Candidato)
criterio = models.ForeignKey(Criterio, default='')
nota = models.PositiveIntegerField(default = 0, validators=[MaxValueValidator(10)])
avaliador = models.ForeignKey('auth.User')
def __str__(self):
return self
views.py:
from django.shortcuts import render, get_object_or_404
from .models import Candidato, Criterio
from django import forms
from .forms import CandForm
from .forms import AvalForm
from django.shortcuts import redirect
def canditato_list(request):
candidatos = Candidato.objects.all()
return render(request, 'app/candidato_list.html', {'candidatos': candidatos})
def candidato_detalhe(request, pk):
candidato = get_object_or_404(Candidato, pk=pk)
return render(request, 'app/candidato_detalhe.html', {'candidato': candidato})
def avaliar(request):
#criterios = Criterio.objects.all()
if request.method == "POST":
form2 = AvalForm(request.POST)
if form2.is_valid():
post = form2.save(commit=False)
post.save()
return redirect('canditato_list', pk=post.pk)
else:
form2 = AvalForm()
return render(request, 'app/avaliacao.html', {'criterios': form2})
def cadastrar(request):
if request.method == "POST":
form = CandForm(request.POST)
if form.is_valid():
post = form.save(commit=False)
post.save()
return redirect('candidato_detalhe', pk=post.pk)
else:
form = CandForm()
return render(request, 'app/cadastro.html', {'form': form})
此视图中调用的模板:
<!DOCTYPE html></!DOCTYPE html>
<html>
<head>
<title>Avaliação</title>
</head>
<body>
<h1>Avaliação</h1>
<form method="POST" class="post-form">
{% csrf_token %}
{{ criterios.as_p }}
<button type="submit" class="save btn btn-default">Guardar</button>
</form>
</body>
</html>
</html>
【问题讨论】:
标签: python-3.x sqlite django-models django-forms