django.db.utils.ProgrammingError: (1146, u"Table'' doesn't exist")解決辦法




一、現象

在數據庫中刪除了一張表,重新執行python manage.py migrate時出錯,提示不存在這張表。

二、原因

主要是因爲django一般在第一次遷移的時候新建表,後面的都不會新建表,而是隻檢查字段等等的變化,所以我們既然已經刪除了這張表,django檢查這張表的字段變化的時候就自然報錯了。

三、解決辦法

解決辦法仍然是執行python manage.py makemigrationspython manage.py migrate,只不過在執行這個之前,把第一次執行遷移創建表的那個記錄刪除掉,否則它檢測到已經執行過第一次了,那麼它後面就不會創建表了。

(1)在該app模塊下,有一個migrations文件夾,除了前兩個文件外,其他的文件都刪除,其實每一次如果有變化的話,這邊就會生成一個文件,下面這個001_initial.py看名字就知道是第一次遷移的時候生成的,也就是因爲有它的存在,所以以後每次再執行就不再創建表了。
這裏寫圖片描述

(2)其次,在數據庫裏面也有相應的記錄,也要刪除。我們仔細看看數據庫裏面存的是什麼,在django_migrations裏面,這個表裏面存的都是每次遷移的記錄,當然記錄的是什麼模塊以及對應的文件名字,比如我們這裏的模塊是dtheme,這裏的文件名叫001_initial,和我們文件夾裏面是一一對應的,同樣,刪除這條記錄。
這裏寫圖片描述

然後再執行python manage.py makemigrationspython manage.py migrate就可以了。需要注意的是,如果這個app模塊下面還有其他的model的話,那麼其他model創建的也要刪除掉,相當於我們這樣的解決方案是針對整個app模塊的,要執行就會全部重新生成,不然會提示部分表已經存在的錯誤。




轉載:https://blog.csdn.net/weisubao/article/details/77187876

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章