Kur*_*eek 8 python django database-migration
我有一个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)
Run Code Online (Sandbox Code Playgroud)
因此name_slug,我想添加的字段是该name字段的 slugified 版本。
我运行了以下数据迁移:
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),
]
Run Code Online (Sandbox Code Playgroud)
但是,如果我之后检查数据库,这些name_slug字段都是空的:
我还反转了迁移并重新运行它,import ipdb; ipdb.set_trace()在重写的save()方法中设置了跟踪 ( ),但它并没有导致 Python 进入调试器,从而确认该方法未被调用。
为什么重写的save()方法没有被调用?我必须复制函数中的代码吗generate_name_slugs?
小智 2
这应该有助于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()
Run Code Online (Sandbox Code Playgroud)