django.db.utils.ProgrammingError: (1146, u“Table‘’ doesn’t exist”)問題的解決
一、現(xiàn)象
最近在數(shù)據(jù)庫中刪除了一張表,重新執(zhí)行python manage.py migrate
時(shí)出錯(cuò),提示不存在這張表。通過查找相關(guān)的資料,最后找到了相關(guān)的解決方法,下面話不多說了,來一起看看詳細(xì)的介紹吧
二、原因
主要是因?yàn)閐jango一般在第一次遷移的時(shí)候新建表,后面的都不會新建表,而是只檢查字段等等的變化,所以我們既然已經(jīng)刪除了這張表,django檢查這張表的字段變化的時(shí)候就自然報(bào)錯(cuò)了。
三、解決辦法
解決辦法仍然是執(zhí)行python manage.py makemigrations和python manage.py migrate
,只不過在執(zhí)行這個(gè)之前,把第一次執(zhí)行遷移創(chuàng)建表的那個(gè)記錄刪除掉,否則它檢測到已經(jīng)執(zhí)行過第一次了,那么它后面就不會創(chuàng)建表了。
(1)在該app模塊下,有一個(gè)migrations文件夾,除了前兩個(gè)文件外,其他的文件都刪除,其實(shí)每一次如果有變化的話,這邊就會生成一個(gè)文件,下面這個(gè)001_initial.py看名字就知道是第一次遷移的時(shí)候生成的,也就是因?yàn)橛兴拇嬖?,所以以后每次再?zhí)行就不再創(chuàng)建表了。
(2)其次,在數(shù)據(jù)庫里面也有相應(yīng)的記錄,也要?jiǎng)h除。我們仔細(xì)看看數(shù)據(jù)庫里面存的是什么,在django_migrations里面,這個(gè)表里面存的都是每次遷移的記錄,當(dāng)然記錄的是什么模塊以及對應(yīng)的文件名字,比如我們這里的模塊是dtheme,這里的文件名叫001_initial,和我們文件夾里面是一一對應(yīng)的,同樣,刪除這條記錄。
然后再執(zhí)行python manage.py makemigrations
和python manage.py migrate
就可以了。
需要注意的是,如果這個(gè)app模塊下面還有其他的model的話,那么其他model創(chuàng)建的表也要?jiǎng)h除掉,相當(dāng)于我們這樣的解決方案是針對整個(gè)app模塊的,要執(zhí)行就會全部重新生成,不然會提示部分表已經(jīng)存在的錯(cuò)誤。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
使用Python字典實(shí)現(xiàn)詞頻統(tǒng)計(jì)的方法
在Python中,利用字典進(jìn)行詞頻統(tǒng)計(jì)是一種常見且強(qiáng)大的方式,通過對文本進(jìn)行預(yù)處理并使用字典數(shù)據(jù)結(jié)構(gòu),可以輕松地統(tǒng)計(jì)文本中每個(gè)單詞出現(xiàn)的頻率,下面將詳細(xì)解釋這個(gè)過程,并提供多種例子,以幫助你更好地理解并應(yīng)用這一技術(shù),需要的朋友可以參考下2023-12-12Python通過PIL獲取圖片主要顏色并和顏色庫進(jìn)行對比的方法
這篇文章主要介紹了Python通過PIL獲取圖片主要顏色并和顏色庫進(jìn)行對比的方法,實(shí)例分析了Python通過PIL模塊操作圖片的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03python監(jiān)控進(jìn)程狀態(tài),記錄重啟時(shí)間及進(jìn)程號的實(shí)例
今天小編就為大家分享一篇python監(jiān)控進(jìn)程狀態(tài),記錄重啟時(shí)間及進(jìn)程號的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07人機(jī)交互程序 python實(shí)現(xiàn)人機(jī)對話
這篇文章主要為大家詳細(xì)介紹了人機(jī)交互程序,初步實(shí)現(xiàn)python人機(jī)對話,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11pycharm 實(shí)現(xiàn)光標(biāo)快速移動(dòng)到括號外或行尾的操作
這篇文章主要介紹了pycharm 實(shí)現(xiàn)光標(biāo)快速移動(dòng)到括號外或行尾的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02Python實(shí)現(xiàn)讀取字符串按列分配后按行輸出示例
這篇文章主要介紹了Python實(shí)現(xiàn)讀取字符串按列分配后按行輸出,涉及Python針對字符串的遍歷、判斷、運(yùn)算等相關(guān)操作技巧,需要的朋友可以參考下2018-04-04pycharm上的python虛擬環(huán)境移到離線機(jī)器上的方法步驟
本人在工作中需要在離線Windows環(huán)境中使用,本文主要介紹了pycharm上的python虛擬環(huán)境移到離線機(jī)器上的方法步驟,具有一定的參考價(jià)值,感興趣的可以了解一下2021-10-10