溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

如何解決django.db.utils.ProgrammingError問(wèn)題

發(fā)布時(shí)間:2021-08-05 11:01:16 來(lái)源:億速云 閱讀:397 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹了如何解決django.db.utils.ProgrammingError問(wèn)題,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

一、現(xiàn)象

最近在數(shù)據(jù)庫(kù)中刪除了一張表,重新執(zhí)行python manage.py migrate時(shí)出錯(cuò),提示不存在這張表。通過(guò)查找相關(guān)的資料,最后找到了相關(guān)的解決方法,下面話(huà)不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧

二、原因

主要是因?yàn)閐jango一般在第一次遷移的時(shí)候新建表,后面的都不會(huì)新建表,而是只檢查字段等等的變化,所以我們既然已經(jīng)刪除了這張表,django檢查這張表的字段變化的時(shí)候就自然報(bào)錯(cuò)了。

三、解決辦法

解決辦法仍然是執(zhí)行python manage.py makemigrations和python manage.py migrate,只不過(guò)在執(zhí)行這個(gè)之前,把第一次執(zhí)行遷移創(chuàng)建表的那個(gè)記錄刪除掉,否則它檢測(cè)到已經(jīng)執(zhí)行過(guò)第一次了,那么它后面就不會(huì)創(chuàng)建表了。

(1)在該app模塊下,有一個(gè)migrations文件夾,除了前兩個(gè)文件外,其他的文件都刪除,其實(shí)每一次如果有變化的話(huà),這邊就會(huì)生成一個(gè)文件,下面這個(gè)001_initial.py看名字就知道是第一次遷移的時(shí)候生成的,也就是因?yàn)橛兴拇嬖?,所以以后每次再?zhí)行就不再創(chuàng)建表了。

如何解決django.db.utils.ProgrammingError問(wèn)題

(2)其次,在數(shù)據(jù)庫(kù)里面也有相應(yīng)的記錄,也要?jiǎng)h除。我們仔細(xì)看看數(shù)據(jù)庫(kù)里面存的是什么,在django_migrations里面,這個(gè)表里面存的都是每次遷移的記錄,當(dāng)然記錄的是什么模塊以及對(duì)應(yīng)的文件名字,比如我們這里的模塊是dtheme,這里的文件名叫001_initial,和我們文件夾里面是一一對(duì)應(yīng)的,同樣,刪除這條記錄。

如何解決django.db.utils.ProgrammingError問(wèn)題

然后再執(zhí)行python manage.py makemigrationspython manage.py migrate就可以了。

需要注意的是,如果這個(gè)app模塊下面還有其他的model的話(huà),那么其他model創(chuàng)建的表也要?jiǎng)h除掉,相當(dāng)于我們這樣的解決方案是針對(duì)整個(gè)app模塊的,要執(zhí)行就會(huì)全部重新生成,不然會(huì)提示部分表已經(jīng)存在的錯(cuò)誤。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“如何解決django.db.utils.ProgrammingError問(wèn)題”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI