栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使用Django / South重命名模型的最简单方法?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用Django / South重命名模型的最简单方法?

为了回答你的第一个问题,简单的模型/表重命名非常简单。运行命令:

./manage.py schemamigration yourapp rename_foo_to_bar --empty

(更新2:尝试

--auto
,而不是
--empty
避免低于警告感谢@KFB的提示。)

如果你使用的是南方的旧版本,则需要

startmigration
而不是
schemamigration

然后手动编辑迁移文件,如下所示:

class Migration(SchemaMigration):    def forwards(self, orm):        db.rename_table('yourapp_foo', 'yourapp_bar')    def backwards(self, orm):        db.rename_table('yourapp_bar','yourapp_foo')   

你可以使用db_table模型类中的meta选项来更简单地完成此操作。但是每次这样做,都增加了代码库的旧版权重-类名与表名不同会使代码难以理解和维护。为了清楚起见,我完全支持执行这样的简单重构。

(更新)我刚刚在生产环境中尝试过此操作,并在应用迁移时收到一个奇怪的警告。它说:

The following content types are stale and need to be deleted:    yourapp | fooAny objects related to these content types by a foreign key will alsobe deleted. Are you sure you want to delete these content types?If you're unsure, answer 'no'.

我回答“不”,一切似乎都很好。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/430258.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号