0

私は取得し続けるこのエラーの解決策を見つけようとしています:

列 posts_post.slug が存在しません

行 1: SELECT "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)
4

2 に答える 2

2

後で SlugField を追加しましたか? その場合、syncdb は既存のデータベース テーブルを更新しません。テーブル全体を削除し、syncdb をやり直してください。

于 2012-10-13T20:22:09.130 に答える
1

エラーは非常に単純です。指定されたデータベース テーブルに列スラッグがありません。モデルの後半で追加した場合、syncdb はテーブルを変更しません (この操作は自動的には実行できません)。この目的のために、Django の必須アプリケーションであるSouthアプリケーションを使用します。

于 2012-10-13T20:26:54.967 に答える