时间:2021-05-22
命令
首先数据库迁移的两大命令:
python manage.py makemigrations & python manage.py migrate前者是将model层转为迁移文件migration,后者将新版本的迁移文件执行,更新数据库。
这两中命令调用默认为全局,即对所有最新更改的model或迁移文件进行操作。如果想对部分app进行操作,就要在其后追加app name:
$ python manage.py makemigrations app_name$ python manage.py migrate app_name如果想要精确到某个迁移文件(0004_xxx.py):
$ python manage.py migrate app_name 0004如果想看迁移文件的执行状态,可以用showmigrations命令查看:
$ python manage.py showmigrationsadmin [X] 0001_initialauth [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)应该知道的一些事就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
migrate文件记录了每一次数据迁移的改变解决方法:重建数据库1.删除数据库错误方法:pythonmanage.pyshellfromapp.modelsim
RAILS_ENV=productionbundleexecrakedb:migrate--trace在执行上面这个命令迁移数据库时,总是报错误:psych.r
今天有碰到这种情况,数据库中有张表没办法通过migration来更改,migrate时报django.db.utils.OperationalError:(10
有时候运行Django的migrate命令不能创建INSTALLED_APPS中的app中的models.py的数据库表,这时可以先运行:pythonmanag
Django项目默认使用sqlite数据库,但是我想用mysql数据库,应该如何配置呢。Django连接mysql数据库的操作,是通过根模块的配置实现的,在项目