Pourquoi ne pas effectuer une migration avec une valeur par défaut, puis ajouter une migration de données personnalisée à votre fichier de migration? Voici un exemple de fichier de migration complète:
from datetime import timedelta
from django.db import migrations, models
import django.utils.timezone
# noinspection PyUnusedLocal
def set_free_credits_added_on(apps, schema_editor):
# noinspection PyPep8Naming
UserProfile = apps.get_model('core', 'UserProfile')
for user_profile in UserProfile.objects.all():
user_profile.free_credits_added_on = user_profile.next_billing - timedelta(days=30)
user_profile.save()
# noinspection PyUnusedLocal
def do_nothing(apps, schema_editor):
pass
class Migration(migrations.Migration):
dependencies = [
('core', '0078_auto_20171104_0659'),
]
operations = [
migrations.AddField(
model_name='userprofile',
name='free_credits_added_on',
# This default value is overridden in the following data migration code
field=models.DateTimeField(
auto_now_add=True,
default=django.utils.timezone.now,
verbose_name='Free Credits Added On'
),
preserve_default=False,
),
migrations.RunPython(code=set_free_credits_added_on, reverse_code=do_nothing),
]
Ici, le champ free_credits_added_on
est de 30 jours avant que le champ next_billing
existant.