Как лучше всего перенести данные в django

После внесения некоторых изменений в мои модели (например, нового поля в модели и новой модели), как лучше всего отразить эти изменения в моей заполненной базе данных?


PS: Я хотел увидеть множество решений в одном рейтинге. Видимо больше решений уже указано здесь.

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
28
0
21 252
6
Перейти к ответу Данный вопрос помечен как решенный

Ответы 6

Зависит от объема изменений. Если это выходит за рамки ALTER, вы делаете серьезную операцию. Сделайте резервные копии модели, а также базы данных, чтобы вы могли вернуться.

Я предпочитаю разместить вашу новую (исправленную, исправленную, расширенную) модель как НОВОЕ приложение. У него не будет URL-адресов или чего-то еще, только модель.

  1. Создание новой модели как нового приложения. Создавайте тесты, чтобы убедиться, что это работает.
  2. syncdb для создания этой промежуточной реализации новой модели.
  3. Напишите небольшую одноразовую утилиту, чтобы запросить вашу старую модель и загрузить новую. Возможно, вы захотите попробовать это на чистом SQL. Я предпочитаю написать простой запрос, построить и сохранить цикл.
  4. После загрузки новой модели вы можете записать ее в файл JSON.

После того, как вы извлекли данные из своей старой модели, вы можете перестроить свою БД в предпочтительном новом формате.

  1. Переместите новую модель в существующее приложение.
  2. Отбросьте старые версии таблиц приложения.
  3. syncdb для создания новых таблиц.
  4. Загрузите файл JSON с данными.

Посмотрите с помощью manage.py sqlall, какие параметры для новых столбцов, и вручную добавьте их в свою базу данных с помощью операторов Alter table. Таким образом, вам не нужно переделывать вашу базу данных; Однако для этого требуются некоторые знания SQL ...

Взгляните на здесь (прокрутите вниз до «Внесение изменений в схему базы данных»)

Ответ принят как подходящий

Я задал аналогичный вопрос здесь и получил довольно много ответов.

Есть довольно много способов сделать это, например, вручную выполнить сброс и перезагрузку с помощью SQL, использовать фикстуры или использовать один из «появляющихся» пакетов эволюции схемы для Django:

Другой метод - использовать аргументы dumpdata и loaddata для manage.py, убивая вашу базу данных между ними:

  1. python manage.py dumpdata > dump.json
  2. С помощью внешнего инструмента удалите все затронутые таблицы или уничтожьте всю базу данных
  3. python manage.py loaddata dump.json

Подробнее см. manage.py документы.

python manage.py sqlreset appname печатает необходимые операторы SQL, но фактически не запускает их.

Vebjorn Ljosa 17.10.2008 17:07

Хорошее решение. Спасибо. В нашем случае в Django 14 нам нужно создать пустую базу данных перед загрузкой фикстур. БД может быть создана с помощью syncdb, однако автоматически созданные типы контента необходимо удалить вручную перед загрузкой дампа.

Simon Steinberger 03.05.2012 16:38

Посмотрите на дату этого ответа. Иногда собственная система миграции Django так же хороша или лучше, как South. @Stian Jensen знает правильный ответ.

Csaba Toth 30.11.2016 19:40

Perform these steps in order may help you:

For more details,

нажмите здесь: http://south.readthedocs.org/en/latest/

1) python manage.py schemamigration apps.appname --initial

На предыдущем шаге по умолчанию создается папка миграции.

2) python manage.py migrate apps.appname --fake

генерирует поддельную миграцию.

3) python manage.py schemamigration apps.appname --auto

Затем вы можете добавить поля по своему усмотрению и выполнить указанную выше команду.

4) python manage.py migrate apps.appname

Затем перенесите файлы в базу данных.

Django теперь имеет собственные встроенные миграции, документированные по адресу:

https://docs.djangoproject.com/en/dev/topics/migrations/

Другие вопросы по теме