關(guān)于django 數(shù)據(jù)庫遷移(migrate)應(yīng)該知道的一些事
命令
首先數(shù)據(jù)庫遷移的兩大命令:
python manage.py makemigrations & python manage.py migrate
前者是將model層轉(zhuǎn)為遷移文件migration,后者將新版本的遷移文件執(zhí)行,更新數(shù)據(jù)庫。
這兩中命令調(diào)用默認(rèn)為全局,即對所有最新更改的model或遷移文件進(jìn)行操作。如果想對部分app進(jìn)行操作,就要在其后追加app name:
$ python manage.py makemigrations app_name $ python manage.py migrate app_name
如果想要精確到某個遷移文件(0004_xxx.py):
$ python manage.py migrate app_name 0004
如果想看遷移文件的執(zhí)行狀態(tài),可以用showmigrations命令查看:
$ python manage.py showmigrations admin [X] 0001_initial auth [X] 0001_initial [X] 0002_alter_permission_name_max_length
顯示django已知的migrations和狀態(tài)。
錯誤
數(shù)據(jù)庫的命令稍有不慎可能就會掉坑。特別是migrate命令,由于django的數(shù)據(jù)庫中包含了migrations的記錄,如果migrations文件丟失,很可能造成migrate失敗。所以有必要將migrations文件加入版本控制,保證開發(fā)時的migrations記錄和文件相匹配。
如果migrate出現(xiàn)了失敗,很可能是因?yàn)閙igration文件包含的變更信息由于當(dāng)前數(shù)據(jù)庫的約束無法完完成。這時就應(yīng)該去數(shù)據(jù)中找到這些記錄或鍵的位置,刪掉重做即可。
一般這些數(shù)據(jù)存在的表為:外鍵約束對應(yīng)的表、auth_permission、django_content_type和django_migrations.
以上這篇關(guān)于django 數(shù)據(jù)庫遷移(migrate)應(yīng)該知道的一些事就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
python?spotlight庫簡化交互式方法探索數(shù)據(jù)分析
這篇文章主要為大家介紹了python?spotlight庫簡化的交互式方法探索數(shù)據(jù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01Python使用protobuf序列化和反序列化的實(shí)現(xiàn)
protobuf是一種二進(jìn)制的序列化格式,相對于json來說體積更小,傳輸更快,本文主要介紹了Python使用protobuf序列化和反序列化的實(shí)現(xiàn),感興趣的可以了解一下2021-05-05python裝飾器-限制函數(shù)調(diào)用次數(shù)的方法(10s調(diào)用一次)
下面小編就為大家分享一篇python裝飾器-限制函數(shù)調(diào)用次數(shù)的方法(10s調(diào)用一次),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04Win10下python3.5和python2.7環(huán)境變量配置教程
這篇文章主要為大家詳細(xì)介紹了Win10下python3.5和python2.7環(huán)境變量配置教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09Python基于textdistance實(shí)現(xiàn)計(jì)算文本相似度
textdistance是Python的第三方庫,用于計(jì)算文本之間的相似度或距離,本文主要為大家詳細(xì)介紹了如何使用textdistance實(shí)現(xiàn)計(jì)算文本相似度,需要的可以了解下2024-03-03