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

來源:互聯網
上載者:User
一、現象

在資料庫中刪除了一張表,重新執行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模組的,要執行就會全部重建,不然會提示部分表已經存在的錯誤。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.