解決Django migrate No changes detected 不能創(chuàng)建表的問題
起因
修改了表結構以后執(zhí)行python3 manage.py migrate 報錯:
django.db.utils.OperationalError: (1091, "Can't DROP 'email'; check that column/key exists")
所以進數(shù)據(jù)庫把對應的表刪除了,想著重新生成這張表.
刪除表以后執(zhí)行:
python3 manage.py makemigrations python3 manage.py migrate
還是不能生成表,提示:No changes detected
處理過程
首先刪除了app對應目錄下的數(shù)據(jù)庫對應的文件和緩存文件:
$ rm -rf migrations/ __pycache__/
重新執(zhí)行:
$ python3 manage.py makemigrations No changes detected $~/code/django/blogproject$ python3 manage.py makemigrations comments Migrations for 'comments': comments/migrations/0001_initial.py - Create model Comment $~/code/django/blogproject$ python3 manage.py migrate Operations to perform: Apply all migrations: admin, auth, blog, comments, contenttypes, sessions, users Running migrations: No migrations to apply.
進入數(shù)據(jù)庫發(fā)現(xiàn)仍然沒有生成表.
然后發(fā)現(xiàn)有一張django_migrations表,里面記錄這有關創(chuàng)建表的記錄,刪除對應的數(shù)據(jù)表:
delete from django_migrations where app='yourappname';
重新執(zhí)行生成數(shù)據(jù)庫命令:
$ python3 manage.py makemigrations comments No changes detected in app 'comments' $~/code/django/blogproject$ python3 manage.py migrate comments Operations to perform: Apply all migrations: comments Running migrations: Applying comments.0001_initial... OK
數(shù)據(jù)表順利生成.
結論
在執(zhí)行
python3 manage.py makemigrations python3 manage.py migrate
操作的時候,不僅會創(chuàng)建0001_initial.py對應的模型腳本,還會創(chuàng)建一個數(shù)據(jù)庫記錄創(chuàng)建的模型.如果想重新生成數(shù)據(jù)庫,需要兩個地方都做刪除.
以上這篇解決Django migrate No changes detected 不能創(chuàng)建表的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- 對Django 中request.get和request.post的區(qū)別詳解
- 基于Django URL傳參 FORM表單傳數(shù)據(jù) get post的用法實例
- 教你如何將 Sublime 3 打造成 Python/Django IDE開發(fā)利器
- Python+Django在windows下的開發(fā)環(huán)境配置圖解
- python Django連接MySQL數(shù)據(jù)庫做增刪改查
- Django如何自定義model創(chuàng)建數(shù)據(jù)庫索引的順序
- Django中對數(shù)據(jù)查詢結果進行排序的方法
- Django中幾種重定向方法
- Python的Django框架中forms表單類的使用方法詳解
- python Django模板的使用方法(圖文)
- Django objects.all()、objects.get()與objects.filter()之間的區(qū)別介紹
- 教你安裝python Django(圖文)
- Django中更新多個對象數(shù)據(jù)與刪除對象的方法
- Django框架中render_to_response()函數(shù)的使用方法
- Django靜態(tài)資源URL STATIC_ROOT的配置方法
- django啟動uwsgi報錯的解決方法
- 詳解Django框架中用戶的登錄和退出的實現(xiàn)
- Django讀取Mysql數(shù)據(jù)并顯示在前端的實例
- Django小白教程之Django用戶注冊與登錄
- Python3+Django get/post請求實現(xiàn)教程詳解
相關文章
在Python中使用matplotlib模塊繪制數(shù)據(jù)圖的示例
這篇文章主要介紹了在Python中使用matplotlib模塊繪制數(shù)據(jù)圖的示例,matplotlib模塊經(jīng)常被用來實現(xiàn)數(shù)據(jù)的可視化,需要的朋友可以參考下2015-05-05提升Python效率之使用循環(huán)機制代替遞歸函數(shù)
這篇文章主要介紹了提升Python效率之使用循環(huán)機制代替遞歸函數(shù)的相關知識,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07python通過ssh-powershell監(jiān)控windows的方法
這篇文章主要介紹了python通過ssh-powershell監(jiān)控windows的方法,涉及Python操作ssh-powershell的相關技巧,需要的朋友可以參考下2015-06-06Python+MediaPipe實現(xiàn)檢測人臉功能詳解
MediaPipe是用于構建多模態(tài)(例如視頻、音頻或任何時間序列數(shù)據(jù))、跨平臺(即eAndroid、IOS、web、邊緣設備)應用ML管道的框架。本文將利用MediaPipe實現(xiàn)檢測人臉功能,需要的可以參考一下2022-02-02Python的Flask框架中SQLAlchemy使用時的亂碼問題解決
這篇文章主要介紹了Python的Flask框架中SQLAlchemy使用時的亂碼問題解決,SQLAlchemy與Python結合對數(shù)據(jù)庫的操作非常方便,需要的朋友可以參考下2015-11-11