Я понимаю, что этот вопрос старый и в то время лучший вариант для миграции данных использует Юг. Теперь Django имеет свою собственную команду migrate
, и процесс немного отличается.
Я добавил эти модели в приложение под названием books
- отрегулируйте соответствующим образом, если это не ваш случай.
Во-первых, добавить поле к Book
и related_name
, по меньшей мере, один или оба из них (или они будут конфликтовать):
class Book(models.Model):
author = models.ForeignKey(Author, related_name='book')
authors = models.ManyToManyField(Author, related_name='books')
title = models.CharField(max_length=100)
Генерация миграции:
$ ./manage.py makemigrations
Migrations for 'books':
0002_auto_20151222_1457.py:
- Add field authors to book
- Alter field author on book
сейчас , создайте пустую миграцию, чтобы сохранить миграцию самих данных:
./manage.py makemigrations books --empty
Migrations for 'books':
0003_auto_20151222_1459.py:
И добавьте к нему следующий контент. Чтобы точно понять, как это работает, проверьте документацию на Data Migrations. Будьте внимательны, чтобы не перезаписывать зависимость миграции.
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from django.db import models, migrations
def make_many_authors(apps, schema_editor):
"""
Adds the Author object in Book.author to the
many-to-many relationship in Book.authors
"""
Book = apps.get_model('books', 'Book')
for book in Book.objects.all():
book.authors.add(book.author)
class Migration(migrations.Migration):
dependencies = [
('books', '0002_auto_20151222_1457'),
]
operations = [
migrations.RunPython(make_many_authors),
]
Теперь удалите author
поле из модели - она должна выглядеть следующим образом:
class Book(models.Model):
authors = models.ManyToManyField(Author, related_name='books')
title = models.CharField(max_length=100)
Создать новую миграцию для этого, и запустить их все:
$ ./manage.py makemigrations
Migrations for 'books':
0004_remove_book_author.py:
- Remove field author from book
$ ./manage.py migrate
Operations to perform:
Synchronize unmigrated apps: messages, staticfiles
Apply all migrations: admin, auth, sessions, books, contenttypes
Synchronizing apps without migrations:
Creating tables...
Running deferred SQL...
Installing custom SQL...
Running migrations:
Rendering model states... DONE
Applying books.0002_auto_20151222_1457... OK
Applying books.0003_auto_20151222_1459... OK
Applying books.0004_remove_book_author... OK
И это оно. Авторы, ранее доступные в book.author
, теперь должны быть в запросе, который вы получаете от book.authors.all()
.
Если это уже не очевидно, убедитесь, что вы создали резервные копии своих данных, прежде чем пытаться выполнить какие-либо миграции. к счастью, копирование sqlite так же просто, как команда 'cp' –
Отъезд [юг] (http://south.aeracode.org/). – Zach
Более конкретно ознакомьтесь с разделом «миграции данных» в учебном пособии: http://south.aeracode.org/wiki/Tutorial3 Это хорошая привычка использовать Юг для всех ваших миграций. –