[英]"Unknown column 'user_id' error in django view
我遇到了一个错误,我不确定是什么原因造成的。
这是错误:
Exception Type: OperationalError
Exception Value:
(1054, "Unknown column 'user_id' in 'field list'")
有谁知道为什么我会收到这个错误? 我想不通。 一切似乎都很好。
我的视图代码如下:
if "login" in request.session:
t = request.POST.get('title', '')
d = request.POST.get('description', '')
fid = request.session["login"]
fuser = User.objects.get(id=fid)
i = Idea(user=fuser, title=t, description=d, num_votes=1)
i.save()
return HttpResponse("true", mimetype="text/plain")
else:
return HttpResponse("false", mimetype="text/plain")
我感谢任何帮助! 谢谢!
编辑:也是一个附带问题。 我是否使用 objects.get(id= 或 objects.get(pk= ?如果我使用主键,我是否需要在模型中声明一个 id 字段或索引?
编辑:以下是相关模型:
class User (models.Model):
first_name = models.CharField(max_length=200)
last_name = models.CharField(max_length=200)
email = models.CharField(max_length=200)
password = models.CharField(max_length=200)
class Idea (models.Model):
user = models.ForeignKey(User)
title = models.CharField(max_length=200)
description = models.CharField(max_length=255)
num_votes = models.IntegerField()
user_id
字段是从Idea
到User
的 FK 引用。 看起来你已经改变了你的模型,而不是更新你的数据库,那么你就会遇到这种问题。
删除旧表,重新运行syncdb。
默认情况下,您的模型表获得一个id
字段。 您可以在查询中将其称为id
。 您也可以使用pk
的同义词。
如果您定义自己的主键字段,则不会获得自动id
字段。 但是您仍然可以使用pk
来引用主键。
您必须展示您的模型才能获得真正的帮助,但您的 Idea 表似乎没有 user_id 列? 您是否修改了 SQL 表结构?
是的,我放下了桌子,一切都很好。 但是,您必须实际进入数据库并删除它们。 “manage.py flush”或“manage.py reset appname”不会自己完成。
-尼克奥
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.