Django: модели не распознаются syncDB или югом после того, как они были преобразованы в отдельные файлы - PullRequest
6 голосов
/ 15 апреля 2011

У меня был большой файл моделей со всеми классами и прочим, и было сложно хранить все в одном файле. Поэтому я реорганизовал это в папку модели, init .py и файлы по одному на каждый класс.

тогда я сделал

manage_noDebug.py schemamigration picviewer --auto
manage_noDebug.py schemamigration migrate picviewer

и юг удалили таблицы из базы данных, но не добавили таблицы model_ *, как я думал. Могу ли я получить его, чтобы забрать файлы моей модели сейчас?

manage_noDebug.py sql picviewer

вывод из выше пустого

структура моих папок:

picviewer / модель / INIT .py Picture.py paperType.py ...

один из классов файлов:

class cartItem(models.Model):
    picture = models.ForeignKey('Picture', null=False)
    paperType = models.ForeignKey('paperType', null=False)
    printSize = models.ForeignKey('printSize', null=False)
    quantity = models.IntegerField(default=1, validators=[validators.MinValueValidator(1)])
    price = models.DecimalField(decimal_places=2,max_digits=8)
    dateCreated = models.DateTimeField(null=False)
    sessionKey = models.ForeignKey(Session, to_field="session_key", null=False)
    user = models.ForeignKey(User,null=True)

    class Meta:
        app_label = 'picviewer'

настройки установленных приложений:

INSTALLED_APPS = (
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.sites',
    'django.contrib.messages',
    'django.contrib.admin',
    'picviewer',
    'south'
)

Я пытался удалить каталог / migrations / из каталога проекта и запустить syncdb:

D:\~Sasha\eclipse_workspace\zavalen>manage_noDebug.py syncdb
Syncing...
No fixtures found.

Synced:
 > django.contrib.auth
 > django.contrib.contenttypes
 > django.contrib.sessions
 > django.contrib.sites
 > django.contrib.messages
 > django.contrib.admin
 > picviewer
 > south

Not synced (use migrations):
 -
(use ./manage.py migrate to migrate these)

Похоже, ни "нативная" syncDB, ни южная схема миграции не видят мои модели.

Вот вывод таблиц из dbShell:

D:\~Sasha\eclipse_workspace\zavalen>manage_noDebug.py dbshell
SQLite version 3.7.5
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite> .tables
auth_group                  auth_user_user_permissions
auth_group_permissions      django_admin_log
auth_message                django_content_type
auth_permission             django_session
auth_user                   django_site
auth_user_groups            south_migrationhistory
sqlite>

Вот папка для моей модели:

D:\~Sasha\eclipse_workspace\zavalen\picviewer\models>dir *.py
Directory of D:\~Sasha\eclipse_workspace\zavalen\picviewer\models

15.04.2011  16:38             1 125 cartItem.py
15.04.2011  16:43             1 283 Collection.py
15.04.2011  16:40               419 ImageSizeRatio.py
15.04.2011  16:43               876 Menu.py
15.04.2011  16:43             1 667 Order.py
15.04.2011  14:07             1 457 OrderForm.py
15.04.2011  16:43               490 OrderStatusHistory.py
15.04.2011  16:43               683 paperType.py
15.04.2011  16:43             3 202 Picture.py
15.04.2011  16:43             1 520 printSize.py
15.04.2011  16:43               687 PurchaseItem.py
15.04.2011  16:43             1 239 Tools.py
15.04.2011  16:11                 0 __init__.py

Ответы [ 2 ]

11 голосов
/ 15 апреля 2011

Чтобы выставить классы, вы должны импортировать их в __init__.py, например:

from Picture import Picture 
from paperType import paperType 
...
__all__ = ['Picture', 'paperType', ...]

Порядок импорта имеет значение .

Если вы нене делайте этого, у вас нет пути доступа picviewer.models.Picture, это picviewer.models.Picture.Picture.

3 голосов
/ 15 апреля 2011

Может отсутствовать app_label: http://docs.djangoproject.com/en/dev/ref/models/options/#app-label. Более того, в syncdb игнорирует импортированные модели охватывает большую часть этого.Если что, пожалуйста, добавьте больше деталей, чтобы ответ мог быть обновлен.

ОБНОВЛЕНИЕ: http://www.djangopro.com/2011/01/django-database-migration-tool-south-explained/ кажется, что модели могут быть в порядке.Миграции могут быть проблемой.

...