带有django的Postgresql DatabaseError列

时间:2012-10-13 20:14:44

标签: database django postgresql

我正在努力找到解决这个错误的方法:

  

列posts_post.slug不存在

     

第1行:选择“posts_post”。“id”,“posts_post”。“title”,“posts_post”......

有谁知道可能导致这种情况的原因?

以下是完整的错误输出:http://dpaste.com/813336/

    from django.db import models
    from django.contrib.auth.models import User
    from datetime import datetime

    class Category(models.Model):
    name = models.CharField(max_length=60)
    def __unicode__(self):
        return self.name

   class Tags(models.Model):
    name = models.CharField(max_length=60)
    def __unicode__(self):
        return self.name

   class Post(models.Model):
    title = models.CharField(max_length=120)
    slug = models.SlugField(max_length=120, unique=True)
    description = models.TextField()
    body = models.TextField()
    published = models.DateTimeField(default=datetime.now)
    categories = models.ForeignKey(Category)
    tags = models.ManyToManyField(Tags)
    def __unicode__(self):
        return self.title
    class Meta:
        ordering = ['-published']
    def get_absolute_url(self):
         return "/%s/%s/%s" % (self.published.year, self.published.month, self.slug)

2 个答案:

答案 0 :(得分:2)

您之后添加了SlugField吗?如果是这样,syncdb不会更新现有数据库表。删除整个表并重新执行syncdb。

答案 1 :(得分:1)

错误很简单 - 您没有给定数据库表中的列slug。如果稍后在模型中添加它,syncdb不会修改表(此操作不能自动完成)。为此,请使用South应用程序,该应用程序是Django必备的应用程序。