OneToOneField - OperationalError

时间:2012-03-04 14:16:20

标签: python django

我正在使用与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) 

1 个答案:

答案 0 :(得分:3)

看起来您已将用户字段添加到模型中,但未将该列添加到数据库中。

syncdb命令将为您创建新表,但它不会添加或修改已存在的表中的列。您有几个选择:

如果您仍在开发应用程序,并且还没有任何重要数据,最简单的方法是删除该表,然后再次运行syncdb以重新创建它。

如果无法删除表,则需要手动运行SQL命令以添加列。

您可能还想调查south,这是Django的架构迁移工具。