使用q.save()的IntegrityError:可能不是NULL

时间:2012-09-12 15:03:07

标签: django

我不知道为什么我会收到错误。以下是观点和祝福

from polls.models import Word, Results

def detail(request):
    q = Word(type="How do you like")
    q.save()
    Word.objects.get(pk=1)

    q.score_set.create(score=5)
    q.score_set.create(score=4)
    q.score_set.create(score=3)
    q.score_set.create(score=2)
    q.score_set.create(score=1)


    return render_to_response('/$')

Models.py

 from django.db import models


class Word(models.Model):
    type = models.CharField(max_length=200)

    def __unicode__(self):
            return self.type

class Results(models.Model):
    word = models.ForeignKey(Word)
    score = models.IntegerField()

    def __unicode__(self):
            return self.score

错误:

IntegrityError at /
polls_word.score may not be NULLRequest Method: GET 
Request URL: Django Version: 1.4.1 
Exception Type: IntegrityError 
Exception Value: polls_word.score may not be NULL 
Exception Location: /home/oveledar/.virtualenvs/django/lib/python2.6/site-packages/django/db/backends/sqlite3/base.py in execute, line 337 
Python Executable: /home/oveledar/.virtualenvs/django/bin/python 
Python Version: 2.6.6 
Python Path: ['/home/oveledar/django/mysite',
 '/home/oveledar/.virtualenvs/django/lib/python2.6/site-packages/setuptools-0.6c11-py2.6.egg',
 '/home/oveledar/.virtualenvs/django/lib/python2.6/site-packages/pip-1.0.2-py2.6.egg',
 '/home/oveledar/.virtualenvs/django/lib64/python26.zip',
 '/home/oveledar/.virtualenvs/django/lib64/python2.6',
 '/home/oveledar/.virtualenvs/django/lib64/python2.6/plat-linux2',
 '/home/oveledar/.virtualenvs/django/lib64/python2.6/lib-tk',
 '/home/oveledar/.virtualenvs/django/lib64/python2.6/lib-old',
 '/home/oveledar/.virtualenvs/django/lib64/python2.6/lib-dynload',
 '/usr/lib/python2.6',
 '/usr/lib64/python2.6',
 '/home/oveledar/.virtualenvs/django/lib/python2.6/site-packages'] 

1 个答案:

答案 0 :(得分:1)

您的表格结构不正确,您需要:

class Results(models.Model):
    word = models.ForeignKey(Word)
    score = models.IntegerField(blank=True, null=True)

之后,删除此表并运行命令:

python manange.py syncdb

blank选项是否需要此节点进行表单验证

null选择它为您的数据库(Null tr​​ue或false)