如果我想升级(更改)我的数据库架构(通过将新字段添加到 Django 模型中来将新字段添加到表中)而不丢失这些表中的数据,最好的解决方案是什么? “syncdb”当然不会添加它们,所以我需要您的建议如何更改表而不删除它们并使用syncdb再次重新创建。
当南不是一个选项时,我只是手动编写脚本进行小的更改。和我用的大的
./manage.py dumpdata appname
http://docs.djangoproject.com/en/dev/ref/django-admin/#dumpdata-appname-appname-appname-model
将其放入文件中。运行正则表达式替换以更新任何添加/删除的字段,然后可以重置该应用程序。我必须承认我有一段时间没有这样做了,但如果需要的话,我可以获取一些特定的代码来为您执行此操作。
它加载备份loaddata
edit
Django 转储单个模型的数据?这个问题是类似的,可能有我正在谈论的信息。
如果您需要,请仍然告诉我,我会为您挖掘我的旧脚本(或写出一个很好的简单脚本)。
UPDATE
./manage.py dumpdata appname --indent=4 > appname.json
#open your fav text editor and do a find/replace
./manage.py reset appname
./manage.py loaddata appname.json
应该可以做到这一点。当您执行查找替换时,您只需要删除不再有的字段并添加不可为空的字段。 (至少)。
Notes:--indent=4 可以很好地为您格式化所有内容。意思是4个空格。
./manage.py 重置仅适用于 django 1.3 之前的版本(啊!),在 django 1.3 中你必须执行./manage dbshell
and drop table
。从命令中找到该sql./manage.py sqlreset appname
.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)