您好,登錄后才能下訂單哦!
這篇文章主要介紹了如何解決django.db.utils.ProgrammingError問題,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
一、現象
最近在數據庫中刪除了一張表,重新執行python manage.py migrate
時出錯,提示不存在這張表。通過查找相關的資料,最后找到了相關的解決方法,下面話不多說了,來一起看看詳細的介紹吧
二、原因
主要是因為django一般在第一次遷移的時候新建表,后面的都不會新建表,而是只檢查字段等等的變化,所以我們既然已經刪除了這張表,django檢查這張表的字段變化的時候就自然報錯了。
三、解決辦法
解決辦法仍然是執行python manage.py makemigrations和python manage.py migrate
,只不過在執行這個之前,把第一次執行遷移創建表的那個記錄刪除掉,否則它檢測到已經執行過第一次了,那么它后面就不會創建表了。
(1)在該app模塊下,有一個migrations文件夾,除了前兩個文件外,其他的文件都刪除,其實每一次如果有變化的話,這邊就會生成一個文件,下面這個001_initial.py看名字就知道是第一次遷移的時候生成的,也就是因為有它的存在,所以以后每次再執行就不再創建表了。
(2)其次,在數據庫里面也有相應的記錄,也要刪除。我們仔細看看數據庫里面存的是什么,在django_migrations里面,這個表里面存的都是每次遷移的記錄,當然記錄的是什么模塊以及對應的文件名字,比如我們這里的模塊是dtheme,這里的文件名叫001_initial,和我們文件夾里面是一一對應的,同樣,刪除這條記錄。
然后再執行python manage.py makemigrations
和python manage.py migrate
就可以了。
需要注意的是,如果這個app模塊下面還有其他的model的話,那么其他model創建的表也要刪除掉,相當于我們這樣的解決方案是針對整個app模塊的,要執行就會全部重新生成,不然會提示部分表已經存在的錯誤。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“如何解決django.db.utils.ProgrammingError問題”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。