我正在使用与User连接的OneToOneField来执行表单提交任务。但是我得到了OperationalError。这是我用于登录后提供表单的一个应用程序。登录过程已成功使用其他应用程序完成。
Models.py:
from django.db import models
from django.forms import ModelForm
from sorl.thumbnail import ImageField
from django.contrib.auth.models import User
class BasicModel(models.Model):
user = models.OneToOneField(User, unique=True, related_name='profile')
name = models.CharField(max_length=200)
dob = models.DateField()
photo = ImageField(upload_to='sample')
class BasicModelForm(ModelForm):
class Meta:
model = BasicModel
exclude = ('user',)
Views.py:
@login_required
def BasicView(request):
if request.method == 'POST':
form = BasicModelForm(request.POST, request.FILES, instance=request.user.profile)
if form.is_valid():
data = form.save()
im = get_thumbnail(data.photo, '100x100', crop='center', quality=99)
return preview(request, data.id, im)
else:
form = BasicModelForm()
return render_to_response("unnamed.html", {'form': form}, context_instance=RequestContext(request))
def preview(request, id, im):
obj = get_object_or_404(BasicModel, pk=id)
return render_to_response("preview.html", {'obj': obj, 'im': im})
错误:
Exception Type: OperationalError
Exception Value: (1054, "Unknown column 'unnamed_basicmodel.user_id' in 'field list'")
Exception Location: /usr/lib/pymodules/python2.7/MySQLdb/connections.py in defaulterrorhandler, line 36
Traceback: form = BasicModelForm(request.POST, request.FILES, instance=request.user.profile)
答案 0 :(得分:3)
看起来您已将用户字段添加到模型中,但未将该列添加到数据库中。
syncdb命令将为您创建新表,但它不会添加或修改已存在的表中的列。您有几个选择:
如果您仍在开发应用程序,并且还没有任何重要数据,最简单的方法是删除该表,然后再次运行syncdb以重新创建它。
如果无法删除表,则需要手动运行SQL命令以添加列。
您可能还想调查south,这是Django的架构迁移工具。