Django:OperationalError没有这样的表


74

我正在使用Django-CMS的Django项目中构建一个相当简单的应用程序,即研究项目。(这是我对项目/应用程序的首次尝试。)它的主要目的是存储各种知识资产(例如,研究人员写的文章,书籍等)。

问题是,当我将浏览器指向/ research /时,我收到一条错误消息,指出表'research_journal'不存在(“ no such table”)。

我正在使用带有sqlite3数据库的Djnago 1.6.5。

python manage.py sql research收益:

BEGIN;
CREATE TABLE "research_researchbase" (
    "id" integer NOT NULL PRIMARY KEY,
    "pub_date" datetime NOT NULL,
    "authors" varchar(200) NOT NULL,
    "year" varchar(25) NOT NULL,
    "title" varchar(200) NOT NULL,
    "subtitle" varchar(200) NOT NULL,
    "image_id" integer NOT NULL REFERENCES "filer_image" ("file_ptr_id"),
    "link" varchar(200) NOT NULL
)
;
CREATE TABLE "research_journal" (
    "researchbase_ptr_id" integer NOT NULL PRIMARY KEY REFERENCES "research_researchbase" ("id"),
    "journal" varchar(200) NOT NULL,
    "abstract" text NOT NULL,
    "citation" varchar(200) NOT NULL
)
;
CREATE TABLE "research_encyclopedia_chapter" (
    "researchbase_ptr_id" integer NOT NULL PRIMARY KEY REFERENCES "research_researchbase" ("id"),
    "encyclopedia" varchar(200) NOT NULL,
    "publisher" varchar(200) NOT NULL,
    "summary" varchar(200) NOT NULL
)
;
CREATE TABLE "research_book" (
    "researchbase_ptr_id" integer NOT NULL PRIMARY KEY REFERENCES "research_researchbase" ("id"),
    "publisher" varchar(200) NOT NULL,
    "summary" varchar(200) NOT NULL
)
;

COMMIT;

我已经跑步python manage.py migrate research并得到:

/Users/XXX/Documents/repos/sfs/env/lib/python2.7/site-packages/app_data/fields.py:2: DeprecationWarning: django.utils.simplejson is deprecated; use json instead.
  from django.utils import simplejson as json

Running migrations for research:
- Nothing to migrate.
 - Loading initial data for research.
Installed 0 object(s) from 0 fixture(s)

我已经运行python manage.py syncdb并获得以下信息:

Syncing...
Creating tables ...
Installing custom SQL ...
Installing indexes ...
Installed 0 object(s) from 0 fixture(s)

Synced:
 > djangocms_admin_style
 > django.contrib.auth
 > django.contrib.contenttypes
 > django.contrib.sessions
 > django.contrib.admin
 > django.contrib.sites
 > django.contrib.sitemaps
 > django.contrib.staticfiles
 > django.contrib.messages
 > mptt
 > south
 > sekizai
 > django_select2
 > hvad

Not synced (use migrations):
 - djangocms_text_ckeditor
 - cms
 - menus
 - djangocms_style
 - djangocms_column
 - djangocms_file
 - djangocms_flash
 - djangocms_googlemap
 - djangocms_inherit
 - djangocms_link
 - djangocms_picture
 - djangocms_teaser
 - djangocms_video
 - reversion
 - polls
 - djangocms_polls
 - aldryn_blog
 - easy_thumbnails
 - filer
 - taggit
 - research
(use ./manage.py migrate to migrate these)

这是models.py:

from django.db import models
from django.utils import timezone
from filer.fields.image import FilerImageField

import datetime

class ResearchBase(models.Model):
    pub_date = models.DateTimeField('date published')
    authors = models.CharField(max_length=200)
    year = models.CharField(max_length=25)
    title = models.CharField(max_length=200)
    subtitle = models.CharField(max_length=200, blank=True)
    image = FilerImageField()
    link = models.CharField(max_length=200, blank=True)

    def __unicode__(self):
        return self.title

    def was_published_recently(self):
        return self.pub_date >= timezone.now() - datetime.timedelta(days=1)


class Journal(ResearchBase):
    journal = models.CharField(max_length=200)
    abstract = models.TextField()
    citation = models.CharField(max_length=200)


class Encyclopedia_Chapter(ResearchBase):
    encyclopedia = models.CharField(max_length=200)
    publisher = models.CharField(max_length=200)
    summary = models.CharField(max_length=200)


class Book(ResearchBase):
    publisher = models.CharField(max_length=200)
    summary = models.CharField(max_length=200)

这是我的views.py(请注意,我正在通过render传递两个对象,请忽略我还没有在整个交易中包含Books类的事实):

from django.shortcuts import render, get_object_or_404
from django.http import HttpResponse, Http404
from django.template import RequestContext, loader

from research.models import Journal, Encyclopedia_Chapter, Book

def research_index(request):
    latest_journal_list = Journal.objects.order_by('-pub_date')[:5]
    latest_chapter_list = Encyclopedia_Chapter.objects.order_by('-pub_date')[:5]

    context = {
        'latest_journal_list': latest_journal_list,
        'latest_chapter_list': latest_chapter_list
    }

    return render(request, 'research/index.html', context)

def journal_detail(request, journal_id):
    journal = get_object_or_404(Journal, pk=journal_id)
    return render(request, 'research/journal_detail.html', {'journal': journal})

def chapter_detail(request, chapter_id):
    chapter = get_object_or_404(Encyclopedia_Chapter, pk=chapter_id)
    return render(request, 'research/chapter_detail.html', {'chapter': chapter})

这是应用程序的url.py:

from django.conf.urls import patterns, url

from research import views

urlpatterns = patterns('',
    url(r'^$', views.research_index, name='research'),
    url(r'^(?P<journal_id>\d+)/$', views.journal_detail, name='journal_detail'),
    url(r'^(?P<chapter_id>\d+)/$', views.chapter_detail, name='chapter_detail'),
)

这是index.html模板:

{% extends 'research/base.html' %}

{% block research_content %}

<div class="container">
    <div class="row featurette">
        <h3 id="research">Peer-reviewed Journal Articles</h3>
        {% if latest_journal_list %}
            <ul id="research">
            {% for journal in latest_journal_list %}
                <li id="research">
                            <img src="{{ journal.image.url }}" id="research">
                            <h4>{{ journal.journal }}</h4>
                            <h5>{{ journal.title }}</h5>
                            <a href="{% url 'research:journal_detail' journal.id %}">Read More</a>
                        </li>
            {% endfor %}
            </ul>
        {% else %}
            <p>No journals are available.</p>
        {% endif %}
    </div>

    <div class="row featurette">
        <h3 id="research">Encyclopedia Chapters</h3>
        {% if latest_chapter_list %}
            <ul id="research">
            {% for chapter in latest_chapter_list %}
                <li id="research">
                            <img src="{{ chapter.image.url }}" id="research">
                            <h4>{{ chapter.journal }}</h4>
                            <h5>{{ chapter.title }}</h5>
                            <a href="{% url 'research:chapter_detail' chapter.id %}">Read More</a>
                        </li>
            {% endfor %}
            </ul>
        {% else %}
            <p>No encyclopedia chapters are available.</p>
        {% endif %}
    </div>
</div>

{% endblock %}

以防万一,这是我的cms_app.py:

from cms.app_base import CMSApp
from cms.apphook_pool import apphook_pool
from django.utils.translation import ugettext_lazy as _


class ResearchApp(CMSApp):
    name = _("Research App")
    urls = ["research.urls"]
    app_name = "research"

apphook_pool.register(ResearchApp)

有什么想法吗?任何帮助将不胜感激。


您是否运行了python manage.py syncdb?
jabez 2014年

是。我已经运行python manage.py syncdb(将结果添加到发布中)。我的印象是,但是通过迁移使用South(南)迁移消除了通过上述命令同步数据库的需要。那不对吗?
布莱恩(Brian)

您是否尝试过再次删除数据库和syncDB?
ppolak

我不想删除整个数据库并丢失其他表(及其数据)。我尝试过,./manage.py sqlclear research | ./manage.py dbshell然后尝试./manage.py syncdb,这清除了研究表。最终,这也不起作用。请在下面查看我的解决方案...
Brian

即使将South添加到项目中,您仍然必须在第一次运行时运行syncdb,只有在此之后才能删除此命令。
jabez 2014年

Answers:


197

页面上的评论对我和其他一些人都有用。它应该得到自己的答案:

python manage.py migrate --run-syncdb

6
不要忘了运行python makemigrations第一
阿米娜Nuraini

有什么--run-syncdb选择?
本雅明·贾法里

8
我找到了它: --run-syncdb ->为没有迁移的应用程序创建表。
本雅明·贾法里

3
这行得通,但是在运行上述命令之前,我必须从中删除.py.pyc迁移文件。<app_dir>/migrationsmakemigrations
Anthony

我运行了此命令,仍然抛出OperationalError。我还删除了db.sqlite3&migrations文件夹,但仍然收到相同的错误。
LC

30

对于Django 1.10,您可能必须这样做python manage.py makemigrations appname


20

看来我的迁移存在问题。

我运行后./manage.py schemamigration research --auto发现,许多字段没有指定默认值。

所以,我跑./manage.py schemamigration research --init./manage.py migrate research

从那里重新运行服务器就可以了!


评论有更多的喜欢,然后是答案本身。@Brian,请使用此有用信息更新答案。
Girishkumar

16

如果有人发现以下任何建议:

python manage.py makemigrations

python manage.py migrate

python manage.py migrate --run-syncdb

失败,您可能需要migrations在应用目录中添加一个名为“ ”的文件夹,并创建一个空__init__.py文件。



5

当您尚未迁移到新创建的表时,将出现此错误,因此,首先在cmd上将命令写入为:python manage.py makemigrations然后再写入另一个命令以应用makemigrations命令进行的这些迁移:python manage.py migrate


3

运行以下命令为我解决了此问题1. python manage.py migration 2. python manage.py makemigrations 3. python manage.py makemigrations appName


2

我正在使用Django 1.9,SQLite3和DjangoCMS 3.2,并且存在相同的问题。我通过运行解决了python manage.py makemigrations。随后出现提示,提示该数据库包含非空值类型,但未设置默认值。它给了我两个选择:1)现在选择一个一次性值,或2)退出并更改models.py中的默认设置。我选择了第一个选项,并将默认值设置为1。重复此四到五次,直到提示说完成为止。然后我跑了python manage.py migrate。现在工作正常。请记住,python manage.py makemigrations首先运行,将创建数据库的修订副本(我的数据库为0004),并且您始终可以恢复到先前的数据库状态。


2

当我进入管理面板时,遇到了同样的错误。您应该改为运行以下命令::python manage.py migrate --run-syncdb。不要忘了包括migration,我跑了:

python manage.py make migrations 接着 python manage.py migrate

当错误仍然存​​在时,我还是尝试使用上面建议的命令进行尝试。


1

这发生在我身上,对我来说,是因为我db.sqlite3从存储库添加为未跟踪。我添加了它并将其推送到服务器,使其正常工作。同时运行makemigartionsmigrate执行此操作。


1

对我有用的东西:

  1. 如果未在models.py中添加类,请找出迁移文件夹中的哪些迁移创建了该表。
  2. 如果您的models.py中已经存在该类,请尝试删除该类并运行 python manage.py makemigrations <appname>
  3. 并且在迁移伪造品时,作为您的错误迁移可能会说找不到使用删除的表 python manage.py migrate <yourappname> --fake
  4. 再次添加课程,然后再次进行迁移python manage.py makemigrations <appname>
  5. 最后再次迁移 python manage.py migrate <appname>

0

我正在将Django CMS 3.4与Django 1.8一起使用。我在Django CMS代码中逐步找到了根本原因。根本原因是Django CMS在进行数据库调用之前未将目录更改为包含SQLite3数据库的文件所在的目录。错误消息是虚假的。根本问题是在错误的目录中进行了SQLite数据库调用。

解决方法是确保在更改为工作目录时,所有Django应用程序都将目录更改回Django Project根目录。


0

如果您到达该列表的底部并找到此答案,我几乎可以肯定它会解决您的所有问题:)就我而言,我删除了一个数据库表,makemigrations而在migrate

所以我有一个非常详细的答案,关于如何重置所有内容 此链接上

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.