我有一个模型SessionCategory
,它类似于以下内容:
from django.db import models
from django.utils.text import slugify
class SessionCategory(models.Model):
name = models.CharField(max_length=255, unique=True)
name_slug = models.CharField(max_length=255, null=True)
def save(self, *args, **kwargs):
if not self.name_slug:
self.name_slug = slugify(self.name)
super().save(*args, **kwargs)
因此,我要添加的name_slug
字段是name
字段的精简版本。
我已经运行了以下数据迁移:
from __future__ import unicode_literals
from django.db import migrations, models
def generate_name_slugs(apps, schema_editor):
SessionType = apps.get_model('lucy_web', 'SessionType')
for session_type in SessionType.objects.all():
session_type.save()
class Migration(migrations.Migration):
dependencies = [
('lucy_web', '0163_auto_20180627_1309'),
]
operations = [
migrations.AddField(
model_name='sessioncategory',
name='name_slug',
field=models.CharField(max_length=255, null=True),
),
migrations.RunPython(
generate_name_slugs,
reverse_code=migrations.RunPython.noop),
]
但是,如果我事后检查数据库,则name_slug
字段全为空:
我还撤消了迁移,并在覆盖的import ipdb; ipdb.set_trace()
方法中设置了跟踪(save()
),然后重新运行了迁移,但这并未导致Python掉入调试器,从而确认了不会调用该方法。
为什么未调用覆盖的save()
方法?我是否必须复制generate_name_slugs
函数中的代码?
答案 0 :(得分:1)
这应该对SessionType有帮助... SessionCategory可以用相同的方式修改...
def generate_name_slugs(apps, schema_editor):
import lucy_web.models as m
for session_type in m.SessionType.objects.all():
session_type.save()