Django 1.7 - makemigrations не обнаруживает изменений

103

Как говорится в названии, я не могу заставить миграции работать.

Первоначально приложение было под 1,6, поэтому я понимаю, что миграций там не будет, и если я запустил python manage.py migrate, я получаю:

Operations to perform:
  Synchronize unmigrated apps: myapp
  Apply all migrations: admin, contenttypes, auth, sessions
Synchronizing apps without migrations:
  Creating tables...
  Installing custom SQL...
  Installing indexes...
Running migrations:
  No migrations to apply.

Если я вношу изменения в любые модели в myapp, он все равно говорит о немиграции, как и ожидалось.

Но если я запустил python manage.py makemigrations myapp, я получаю:

No changes detected in app 'myapp'

Не похоже, что и как я запускаю команду, она никогда не обнаруживает, что приложение имеет изменения, и не добавляет никаких файлов миграции в приложение.

Есть ли способ заставить приложение перейти на миграцию и по существу сказать: "Это моя база для работы" или что-то еще? Или я что-то упускаю?

Моя база данных является PostgreSQL, если это вообще помогает.

  • 0
    Предлагаемые решения не работают для меня, так что вот мое решение, если кто-то сталкивается с той же проблемой! 1. Удалите файлы миграции во всех приложениях. 2. Удалите базу данных и создайте ее снова. 3. Запустите makemigrations и команды миграции. PS Сначала попробуйте выполнить шаги 1 и 3. Если ошибка не устранена, выполните шаги 1-3.
Теги:
django-migrations
django-1.7

22 ответа

22
Лучший ответ

Хорошо, похоже, я пропустил очевидный шаг, но опубликую это, если кто-то другой сделает то же самое.

При обновлении до 1.7 мои модели стали неуправляемыми (managed = False) - раньше я их использовал как True, но, похоже, он вернулся.

Удаление этой строки (по умолчанию True), а затем запуск makemigrations сразу же создал модуль миграции и теперь он работает. makemigrations не будет работать на неуправляемых таблицах (что очевидно в ретроспективе)

  • 4
    Смотрите документы здесь: docs.djangoproject.com/en/dev/ref/models/options/#managed
  • 3
    Пожалуйста, уточните - где вы изменили / добавили "managed = False"? У меня та же проблема
Показать ещё 4 комментария
152

Если вы переходите из существующего приложения, которое вы сделали в django 1.6, вам нужно сделать один предварительный шаг (как я узнал), перечисленные в документации:

python manage.py makemigrations your_app_label

Документация не делает очевидным, что вам нужно добавить метку приложения в команду, так как первое, что вам нужно сделать, это python manage.py makemigrations, которая не удастся. Первоначальная миграция выполняется при создании вашего приложения в версии 1.7, но если вы пришли из 1.6, это не было бы выполнено. Подробнее см. 'Добавление миграции в приложения в документации.

  • 1
    Хороший ответ для людей, пришедших из Django 1.6! Спасибо!
  • 0
    Что делать, если у меня есть более одного приложения? Должен ли я сделать python manage.py makemigrations APP_LABEL для каждого?
Показать ещё 2 комментария
17

Мое решение не было рассмотрено здесь, поэтому я отправляю его. Я использовал syncdb для проекта - только для его запуска и запуска. Затем, когда я попытался начать использование Django-миграций, он сначала подделывал их, а потом говорил, что это "ОК", но ничего не происходит с базой данных.

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

Затем я только сделал начальную миграцию с помощью:

./manage.py makemigrations my_app

а затем:

./manage.py migrate my_app

Теперь я могу выполнять миграции без проблем.

  • 0
    К вашему сведению: очень важно, чтобы он сказал здесь: «файлы, а также записи базы данных». Если вы удалите записи базы данных, но также не файлы (кроме __init.py__ , это не будет работать).
14

Согласитесь с @furins. Если все выглядит по порядку, и все же возникает эта проблема, проверьте, существует ли какой-либо метод свойств с тем же заголовком, что и атрибут, который вы пытаетесь добавить в класс модели.

  • Удалить метод с похожим именем как добавляемый атрибут.
  • manage.py makemigrations my_app
  • manage.py migrate my_app
  • Добавьте методы назад.
7

Это довольно глупая ошибка, но с добавлением дополнительной запятой в конце строки объявления поля в классе модели делает линию недействительной.

Это происходит, когда вы копируете вставку def. из миграции, которая сама определяется как массив.

Хотя, возможно, это помогло бы кому-то: -)

  • 1
    Ваш комментарий помог мне найти мою проблему! У меня не было запятой в конце последнего выбора в списке выбора ... видимо, Django очень обидчивый.
  • 1
    @ Максим: это было маловероятной причиной вашей проблемы: список без запятой в конце по-прежнему остается списком. Другое дело кортежи: если в кортеже всего 1 элемент, вам нужна запятая после него.
Показать ещё 1 комментарий
5

Возможно, я слишком поздно, но вы пытались создать в своем приложении migrations папку с файлом __init__.py?

  • 1
    Если у вас есть эта «makemigrations», создаст миграции для приложения. В противном случае вам потребуется запустить makemigrations app_name (который создает этот файл)
5

После меня работали:

  • Добавить имя приложения в settings.py
  • использовать 'python manage.py makemigrations'
  • использовать 'python manage.py migrate'

Работал для меня: Python 3.4, Django 1.10

5

Такие люди, как я, которым не нравятся миграции, могут использовать следующие шаги.

  • Удалите изменения, которые вы хотите синхронизировать.
  • Запустите python manage.py makemigrations app_label для начальной миграции.
  • Запустите python manage.py migrate для создания таблиц перед внесением изменений.
  • Вставить изменения, которые вы удаляете с первого шага.
  • Запустите 2. и 3. шаги.

Если вы смутили какие-либо из этих шагов, прочитайте файлы миграции. Измените их, чтобы исправить вашу схему или удалить ненужные файлы, но не забудьте изменить следующую часть зависимостей файла миграции;)

Я надеюсь, что это поможет кому-то в будущем.

5

Ответ на этот пост stackoverflow, cdvv7788 Миграции в Django 1.7

Если вы в первый раз переносите это приложение, вы должны использовать:

manage.py makemigations myappname После этого вы можете сделать:

manage.py migrate Если у вас есть приложение в базе данных, измените его модель и он не обновляет изменения в макэмиграции, которые вы, вероятно, не имеете еще мигрировала. Измените модель на первоначальную форму, запустите первая команда (с именем приложения) и мигрировать... она подделает ее. однажды вы делаете это, чтобы вернуть изменения в вашей модели, запустить makemigrations и мигрировать снова, и он должен работать.

У меня была такая же проблема, и работа над ней работала отлично.

Я переместил приложение django в cloud9 и по какой-то причине я никогда не попадал в первоначальную миграцию.

5

Может быть, это поможет кому-то. Я использовал вложенное приложение. project.appname, и у меня на самом деле был проект и project.appname в INSTALLED_APPS. Удаление проекта из INSTALLED_APPS позволило обнаружить изменения.

4

Вы хотите проверить settings.py в списке INSTALLED_APPS и убедиться, что все приложения с моделями указаны там.

Запуск makemigrations в папке проекта означает, что он будет обновлять все таблицы, связанные со всеми приложениями, включенными в settings.py для проекта. После того, как вы включите его, makemigrations будет автоматически включать приложение (это экономит много работы, поэтому вам не нужно запускать makemigrations app_name для каждого приложения в вашем проекте/сайте).

3

Добавление этого ответа, потому что только этот метод помог мне.

Я удалил папку migrations makemigrations и migrate.
Он по-прежнему сказал: никаких миграций не требуется.

Я пошел в папку migrate и открыл последний созданный файл,
комментарий миграции, которую я хотел (она была обнаружена и введена там)
и снова запустите migrate.

Это в основном редактирование файла миграции вручную.
Сделайте это, только если вы понимаете содержимое файла.

  • 1
    Спасибо вам большое! Это помогло
  • 1
    Это сработало. Спасибо
3

На всякий случай у вас есть определенное поле, которое не идентифицируется с помощью makemigrations: дважды проверьте, если у вас есть свойство с тем же именем.

Пример:

field = django.db.models.CharField(max_length=10, default = '', blank=True, null=True)

# ... later

@property
def field(self):
    pass

свойство будет "перезаписывать" определение поля, поэтому изменения не будут идентифицироваться с помощью makemigrations

  • 0
    Связанный облом должен иметь искаженное поле, которое все еще избегает проверки / проверки. Я определил hourly_rate = models.DecimalField (пропуская завершающий '()'), и он просто молча провалился.
2

Это может произойти по следующим причинам:

  • Вы не добавили приложение в список INSTALLED_APPS в settings.py (Вы должны добавить либо имя приложения, либо точечный путь к подклассу AppConfig в apps.py в папке приложения, в зависимости от используемой версии django). См. Документацию: INSTALLED_APPS
  • В этих приложениях нет папки migrations. (Решение: просто создайте эту папку).
  • У вас нет файла __init__.py внутри папки migrations этих приложений. (Решение: просто создайте пустой файл с именем __ init __. Py)
  • У вас нет файла __init__.py внутри папки приложения. (Решение: просто создайте пустой файл с именем __ init __. Py)
  • У вас нет файла models.py в приложении
  • Ваш класс Python (предположительно являющийся моделью) в models.py не наследует django.db.models.Model
  • У вас есть семантическая ошибка в определении моделей в models.py
  • 1
    Я клонировал свой проект, и папка миграций не была перенесена в репозиторий, поэтому мне пришлось добавить директора по миграциям, затем я добавил init .py и смог выполнить миграцию. Благодаря вам
  • 0
    Это помогло решить мою проблему. Спасибо, приятель!
Показать ещё 2 комментария
2

Убедитесь, что ваша модель не соответствует abstract. Я действительно совершил эту ошибку, и мне потребовалось некоторое время, поэтому я подумал, что я опубликую ее.

2

Использовал ли u schemamigration my_app --initial после переименования старой папки миграции? Попробуй. Может работать. Если нет - попробуйте воссоздать базу данных и сделать syncdb + migrate. Это сработало для меня...

  • 10
    schemamigration команд schemamigration существует - я думаю, что это часть Юга? У меня сейчас нет папки для миграции. Удаление моего models.py и inspectdb , похоже, ничего не сделали.
  • 2
    schemamigration была с юга. makemigrations это его замена.
Показать ещё 2 комментария
1
./manage makemigrations
./manage migrate

Миграция отслеживает изменения в БД, поэтому, если вы меняетесь с неуправляемого на управляемый, вам нужно убедиться, что таблица базы данных youre актуальна в отношении модели, с которой вы имеете дело.

Если вы все еще находитесь в режиме dev, я лично решил удалить файлы миграции в своей среде IDE, а также в таблице django_migrations, относящейся к моей модели, и повторить указанную выше команду.

ПОМНИТЕ: если у вас есть миграция, которая заканчивается на _001 в вашей среде IDE и _003 в вашей базе данных. Django увидит только, закончится ли переход на _004 для обновления.

2 (миграция кода и db) связаны и работают в тандеме.

Счастливое кодирование.

1

Возможно, это поможет кому-то.

Я удалил свой models.py и ожидаемый makemigrations для создания операторов DeleteModel.

Не забудьте удалить *.pyc файлы!

1

Может быть, это может помочь кому-то, у меня была та же проблема.

Я уже создал две таблицы с классом сериализатора и представлениями. Поэтому, когда я хотел обновить, у меня была эта ошибка.

Я выполнил следующие шаги:

  • Я сделал .\manage.py makemigrations app
  • Я выполнил .\manage.py migrate
  • Я удалил обе таблицы моего models.py
  • Я удалил все ссылки на мои таблицы из сериализатора и класса вида.
  • Я выполнил шаги 1 и 2.
  • Я получил мои изменения только в models.py
  • Я снова выполнил шаг 5.
  • Я восстановил все свои изменения.

Если вы работаете с Pycharm, местная история очень полезна.

1

Недавно я обновил Django с 1,6 до 1,8 и для них было мало приложений и миграций. Я использовал юг и schemamigrations для создания миграции в Django 1.6, который был опущен в Django 1.8.

Когда я добавил новые модели после обновления, команда makemigrations не обнаружила никаких изменений. И затем я попробовал решение, предложенное @drojf (1-й ответ), он работал нормально, но не смог применить фальшивую начальную миграцию (python manage.py --fake-initial). Я делал это, так как мои таблицы (старые таблицы) уже были созданы.

Наконец, это сработало для меня, удалило новые модели (или изменения модели) с models.py, а затем пришлось удалить (или переименовать для безопасного резервного копирования) папку миграций всех приложений и запустить mathemigations для python manage.py для всех приложений, затем сделал python manage.py migrate --fake-initial. Это работало как прелесть. Когда начальная миграция создается для всех приложений и поддельная начальная миграция, добавлены новые модели и выполняются регулярные процессы makemigrations и переносятся на это приложение. Изменения были обнаружены сейчас, и все прошло хорошо.

Я просто подумал о том, чтобы поделиться им здесь, если кто-то сталкивается с такой же проблемой (имея schemamigrations юга для своих приложений), это может помочь им:)

1

У меня была такая же проблема, когда мне приходилось запускать makemigrations дважды и всевозможные странные действия. Оказалось, что корень проблемы состоял в том, что я использовал функцию для установки дат по умолчанию в своих моделях, поэтому миграция обнаруживала изменения каждый раз, когда я запускал makemigrations. Ответ на этот вопрос поставил меня на правильный путь: Избегайте повторного создания поля даты

0

Добавление моего 2c, поскольку ни один из этих решений не работал у меня, но это произошло...

Я только что запустил manage.py squashmigrations и удалил старые миграции (как файлы, так и строки в таблице базы данных django.migrations).

В последнем файле миграции осталась такая строка:

replaces = [(b'my_app', '0006_auto_20170713_1735'), (b'my_app', '0007_auto_20170713_2003'), (b'my_app', '0008_auto_20170713_2004')]

Это, по-видимому, запутало Django и вызвало странное поведение: запуск manage.py makemigrations my_app воссоздал первоначальную миграцию, как будто никого не было. Удаление строки replaces... устраняет проблему!

Ещё вопросы

Сообщество Overcoder
Наверх
Меню