我想改变一个模型中特定字段的名称:

class Foo(models.Model):
    name = models.CharField()
    rel  = models.ForeignKey(Bar)

应改为:

class Foo(models.Model):
    full_name     = models.CharField()
    odd_relation  = models.ForeignKey(Bar)

使用South最简单的方法是什么?


当前回答

只需更改模型并在1.9中运行makemigrations即可

Django会自动检测到你已经删除并创建了一个字段,并询问:

Did you rename model.old to model.new (a IntegerField)? [y/N]

说“是”,就会创建正确的迁移。魔法。

其他回答

Django 1.7引入了迁移,所以现在你甚至不需要安装额外的包来管理你的迁移。

要重命名你的模型,你需要先创建空迁移:

$ manage.py makemigrations <app_name> --empty

然后你需要像这样编辑你的迁移代码:

from django.db import models, migrations

class Migration(migrations.Migration):

dependencies = [
    ('yourapp', 'XXXX_your_previous_migration'),
]

operations = [
    migrations.RenameField(
        model_name='Foo',
        old_name='name',
        new_name='full_name'
    ),
    migrations.RenameField(
        model_name='Foo',
        old_name='rel',
        new_name='odd_relation'
    ),
]

之后你需要运行:

$ manage.py migrate <app_name>

您可以使用db。rename_column函数。

class Migration:

    def forwards(self, orm):
        # Rename 'name' field to 'full_name'
        db.rename_column('app_foo', 'name', 'full_name')




    def backwards(self, orm):
        # Rename 'full_name' field to 'name'
        db.rename_column('app_foo', 'full_name', 'name')

db的第一个参数。rename_column是表名,所以记住Django如何创建表名是很重要的:

Django自动从模型类的名称和包含它的应用程序的名称中派生出数据库表的名称。模型的数据库表名是通过将模型的“应用程序标签”(在manage.py startapp中使用的名称)与模型的类名连接起来构造的,并在它们之间使用下划线。

如果您有一个多词的、驼峰式的模型名,比如projtem,那么表名将是app_projtem(也就是说,项目和项之间不会插入下划线,即使它们是驼峰式的)。

只需更改模型并在1.9中运行makemigrations即可

Django会自动检测到你已经删除并创建了一个字段,并询问:

Did you rename model.old to model.new (a IntegerField)? [y/N]

说“是”,就会创建正确的迁移。魔法。

我不知道db。重命名列,听起来很方便,但是在过去,我将新列作为一个模式迁移添加,然后创建一个数据迁移以将值移动到新字段,然后再创建第二个模式迁移以删除旧列

我是这么做的:

在模型中更改列名(在本例中为myapp/models.py) 执行。/manage.py schemamigration myapp renaming_column_x——auto

注意,renaming_column_x可以是您喜欢的任何名称,它只是一种为迁移文件提供描述性名称的方式。

这将生成一个名为myapp/migrations/000x_renaming_column_x.py的文件,该文件将删除旧列并添加一个新列。

修改此文件中的代码,将迁移行为更改为简单的重命名:

class Migration(SchemaMigration):

    def forwards(self, orm):
        # Renaming column 'mymodel.old_column_name' to 'mymodel.new_column_name'
        db.rename_column(u'myapp_mymodel', 'old_column_name', 'new_column_name')

    def backwards(self, orm):
        # Renaming column 'mymodel.new_column_name' to 'mymodel.old_column_name'
        db.rename_column(u'myapp_mymodel', 'new_column_name', 'old_column_name')