关于django 数据库迁移(migrate)应该知道的一些事
命令
首先数据库迁移的两大命令:
pythonmanage.pymakemigrations&pythonmanage.pymigrate
前者是将model层转为迁移文件migration,后者将新版本的迁移文件执行,更新数据库。
这两中命令调用默认为全局,即对所有最新更改的model或迁移文件进行操作。如果想对部分app进行操作,就要在其后追加appname:
$pythonmanage.pymakemigrationsapp_name $pythonmanage.pymigrateapp_name
如果想要精确到某个迁移文件(0004_xxx.py):
$pythonmanage.pymigrateapp_name0004
如果想看迁移文件的执行状态,可以用showmigrations命令查看:
$pythonmanage.pyshowmigrations admin [X]0001_initial auth [X]0001_initial [X]0002_alter_permission_name_max_length
显示django已知的migrations和状态。
错误
数据库的命令稍有不慎可能就会掉坑。特别是migrate命令,由于django的数据库中包含了migrations的记录,如果migrations文件丢失,很可能造成migrate失败。所以有必要将migrations文件加入版本控制,保证开发时的migrations记录和文件相匹配。
如果migrate出现了失败,很可能是因为migration文件包含的变更信息由于当前数据库的约束无法完完成。这时就应该去数据中找到这些记录或键的位置,删掉重做即可。
一般这些数据存在的表为:外键约束对应的表、auth_permission、django_content_type和django_migrations.
以上这篇关于django数据库迁移(migrate)应该知道的一些事就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。