Я хочу добавить поле ForeignKey
в мою модель. Для этого я сделал 3 шага:
- Добавлено поле
ForeignKey
сnull=True
в мою модель, а затем создалоschemamigration
. - Создал
datamigration
, чтобы заполнить этот внешний ключ разумным значением. После применения этой миграции я уверен, что в этом поле нет объекта с нулевым значением. - Изменено это поле
ForeignKey
наnull=False
, а затем создано другоеschemamigration
.
Однако у меня возникают проблемы на шаге 3:
? The field 'MyModel.fkfield' does not have a default specified, yet is NOT NULL.
? Since you are making this field non-nullable, you MUST specify a default
? value to use for existing rows. Would you like to:
? 1. Quit now, and add a default to the field in models.py
? 2. Specify a one-off value to use for existing columns now
? Please select a choice:
Ну... Значение по умолчанию для этого поля не имеет смысла, а также теперь я уверен, что ни один объект не имеет это поле как NULL. Итак... Я не знаю, как правильно ответить на этот вопрос. Если бы я мог, я бы сказал: "Не устанавливайте значение по умолчанию, и бросайте ошибку, если вы найдете NULL в этом столбец".
Теперь, как обходной путь, чтобы решить этот вопрос, я выбираю опцию 2
, а затем используя 1
как одноразовое значение по умолчанию. Это довольно плохое решение, но по крайней мере south
не жалуется на него и создает миграцию.
- Каков правильный способ изменения поля в
NOT NULL
? (используяsouth
) - Что делать, если
south
запрашивает у меня значение по умолчанию для поля, которое не должно иметь этого?
Я использую django-1.2
и south-0.7
.
Связанный вопрос: Django South - превращение null = True в поле null = False
Связанная документация: Часть 3: Расширенные команды и миграция данных
(сноска: здесь, в StackOverflow, у нас есть два тега, которые кажутся мне равными: "django-south" и "south", но у меня недостаточно репутации, чтобы предлагать синонимы)