亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Django-migrate報錯問題解決方案

瀏覽:210日期:2024-10-10 10:31:57

python3 manage.py makemigrations # 生成數據庫遷移文件python3 manage.py migrate # 遷移數據庫

簡簡單單兩條命令就完成了django的數據庫遷移

但是今天一天的時間都耽誤在這了,一點都不夸張的那種,,早上去公司討論需求之后,研究了一下需要更改一下數據庫,在執(zhí)行makemigrations的時候OK沒有問題,但是migrate就報錯了

1.報錯: XX表已經存在,django.db.utils.OperationalError: (1050, 'Table XX already exists

我:刪表,但是報錯,Cannot delete or update a parent row: a foreign key constraint fails 跟YY表存在外鍵關系,無法刪除,

百度了一番之后:1、SET foreign_key_checks = 0; // 先設置外鍵約束檢查關閉

2、drop table XX; // 刪除數據,表或者視圖

3、SET foreign_key_checks = 1; // 開啟外鍵約束檢查,以保持表結構完整性 

2.表刪了之后重新執(zhí)行migrate,又報錯別的表存在,如此一直循環(huán)往復,我都懷疑這是人家寫的一個while True,

我:找到了第二種解決方案:python manage.py migrate myapp --fake # 切記把myapp換成你要執(zhí)行的APP名稱

這條命令可以順利執(zhí)行,沒有報錯,但是又找不到對應生成的表在哪里,頂如還是說不能成功

3.將之前執(zhí)行makemigrations生成的migrations文件夾刪除,重新來過,OK,還是一樣的毛病,

4.重新創(chuàng)建了database之后,重新來過,只生成了django自帶的那幾張表,然而項目里大多的數據存儲都是依靠我在每一個app里創(chuàng)建的table里呀

5.將每個APP下的migrations都刪掉,database也重新來過,好嘛,連最基本的數據庫遷移文件夾都不能生成了,一瞬間有種悔不當初的感覺,但是又能怎么樣呢,就是需要調整數據庫呀

6.這個時候重頭開始來過,千萬不要慌,檢查settings里是否把每一個APP都注冊到,項目同名目錄下的__init__.py里是否包含了

import pymysql

pymysql.install_as_MySQLdb()

7.沒有問題之后這樣去執(zhí)行數據庫遷移的命令 

python3 manage.py migrate # 生成django自帶的數據庫python3 manage.py makemigrations appname # 將appname換成你要遷移的那個app的名稱python3 manage.py migrate appname # 同理,換名

至此,一個小小的問題,真的就花了我一天的時間,好在終于解決了,

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: xxx国产 | 久草久热| 久久久久香蕉视频 | 啪啪午夜视频 | 偷窥自拍15p | 黄色一级视频免费观看 | 鲁久久| 久久国产香蕉 | 国产精品偷伦视频免费手机播放 | 天天色天天碰 | 美女污污视频网站 | qyule极品视频在线一区 | 亚洲人和日本人hd | 久久激情免费视频 | 久久性妇女精品免费 | 香蕉成人999视频 | 国产精品麻豆网站 | 国产一区二区三区成人久久片 | 一区二区三区四区精品 | 国产又色又爽黄的网站免费 | 播放一级黄色录像 | 国产精品第二页在线播放 | 日韩女性性生生活视频 | 午夜水蜜桃视频在线观看 | 国产亚洲精品国产福利在线观看 | 一级美女片 | 亚洲精品tv久久久久久久久久 | 美国a级 | 中文字幕精品视频 | 精品自拍视频在线观看 | 成年女人a毛片免费视频 | 亚洲精品综合久久 | 国产高清免费午夜在线视频 | 色噜噜五月综合激情久久爱 | 欧美黑人巨大肥婆性视频 | 国产一级爱片在线播放 | 国产婷婷综合在线视频 | 中文字幕在线观 | 午夜精品国产爱在线观看不卡 | 国产中文久久精品 | 国产99网站 |