您好,登錄后才能下訂單哦!
這篇文章主要介紹了如何解決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)建表了。
(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)的,同樣,刪除這條記錄。
然后再執(zhí)行python manage.py makemigrations
和python 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í)!
免責(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)容。