Я хочу добавить поле 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", но у меня недостаточно репутации, чтобы предлагать синонимы)