av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

Django migrate報錯的解決方案

瀏覽:2日期:2024-09-05 18:55:40
前言

在講解如何解決migrate報錯原因前,我們先要了解migrate做了什么事情,migrate:將新生成的遷移腳本。映射到數(shù)據(jù)庫中。創(chuàng)建新的表或者修改表的結構。

問題1:migrate怎么判斷哪些遷移腳本需要執(zhí)行?

它會將代碼中的遷移腳本和數(shù)據(jù)庫中django_migrations中的遷移腳本進行對比,如果發(fā)現(xiàn)數(shù)據(jù)庫中,沒有這個遷移腳本,那么就會執(zhí)行這個遷移腳本。

問題2:migrate做了什么事情

將相關的遷移腳本翻譯成SQL語句,在數(shù)據(jù)庫中執(zhí)行這個SQL語句。 如果這個SQL語句執(zhí)行沒有問題,那么就會將這個遷移腳本的名字記錄到django_migrations中。實戰(zhàn)案例

當我們了解清楚migrate的作用后,我們來看一個案例首先我們創(chuàng)建一個項目orm_migrations_demo,接著創(chuàng)建2個app應用front和article,代碼結構如下圖

Django migrate報錯的解決方案

接著在front.models.py和article.models.py中創(chuàng)建模型

# front.models.pyclass Article(models.Model): name = models.CharField(max_length=200)# article.models.pyclass FrontUser(models.Model): name = models.CharField(max_length=200)

接著在settings.py的INSTALL_APPS中將app注冊

INSTALLED_APPS = [ ’django.contrib.admin’, ’django.contrib.auth’, ’django.contrib.contenttypes’, ’django.contrib.sessions’, ’django.contrib.messages’, ’django.contrib.staticfiles’, ’front’, ’article’,]

接著我們打開命令行,輸入makemigrations article,再輸入makemigrations front,此時2個app目錄中都會出現(xiàn)遷移文件0001_initial.py,此時數(shù)據(jù)庫中是沒有表的,因為還沒有執(zhí)行遷移命令接著我們執(zhí)行migrate article,再輸入migrate front,migrate發(fā)現(xiàn)數(shù)據(jù)庫中沒有遷移腳本,那么就會執(zhí)行剛才生成的2個遷移腳本,將遷移腳本翻譯成SQL語句,然后創(chuàng)建了2張表,執(zhí)行完成后,會將遷移腳本記錄到django_migrations表中,數(shù)據(jù)庫中表結構如下:

Django migrate報錯的解決方案

django_migrations表中內(nèi)容如下:

Django migrate報錯的解決方案

接下來我們在article.models.py中添加一個content字段

class Article(models.Model): name = models.CharField(max_length=200) content = models.CharField(max_length=200, null=True)

然后執(zhí)行命令makemigrations article,會在項目中生成遷移文件0002_article_content.py,接著執(zhí)行migrate article,執(zhí)行遷移腳本,此時數(shù)據(jù)庫中表django_migrations有3個遷移腳本

Django migrate報錯的解決方案

現(xiàn)在我們來模仿錯誤信息內(nèi)容,我們將數(shù)據(jù)庫中django_migrations表中的0002_article_content這行記錄刪除,然后我們來看下0002_article_content的代碼

class Migration(migrations.Migration): dependencies = [(’article’, ’0001_initial’), ] operations = [migrations.AddField( model_name=’article’, name=’content’, field=models.CharField(max_length=200, null=True),), ]

這個遷移腳本的作用是為article模型添加content字段,但是我們現(xiàn)在看一下article中的字段:

Django migrate報錯的解決方案

從上圖中我們可以清楚的看到article表中已經(jīng)有了content字段,那么我們再執(zhí)行migrate article命令時,就會報錯,說content字段重復了,報錯信息如下

django.db.utils.OperationalError: (1060, 'Duplicate column name ’content’')

如果發(fā)生這種報錯信息,解決辦法是在migrate命名后添加參數(shù)--fake,--fake可以將指定的遷移腳本名字添加到數(shù)據(jù)庫中。但是并不會把遷移腳本轉換為SQL語句去修改數(shù)據(jù)庫中的表

所以,我們可以執(zhí)行命名migrate article --fake,會在django_migrations表中插入遷移腳本記錄0002_article_content,如下圖

Django migrate報錯的解決方案

此時數(shù)據(jù)庫中表結構和django中的表結構完全一致,接下來執(zhí)行遷移命令,就不會報錯了

第一種報錯情況總結

原因:執(zhí)行migrate命令會報錯的原因是。數(shù)據(jù)庫的django_migrations表中的遷移版本記錄和代碼中的遷移腳本不一致導致的。解決辦法:使用--fake參數(shù):首先對比數(shù)據(jù)庫中的遷移腳本和代碼中的遷移腳本。然后找到哪個不同,之后再使用--fake,將代碼中的遷移腳本添加到django_migrations中,但是并不會執(zhí)行sql語句。這樣就可以避免每次執(zhí)行migrate的時候,都執(zhí)行一些重復的遷移腳本。

第二種報錯情況

如果我們不管怎么執(zhí)行migrate命令都會報錯,那么就執(zhí)行第二種方案

將出問題的app下的所有模型,都和數(shù)據(jù)庫中的表保持一致。將出問題的app下的所有遷移腳本文件都刪掉。再在django_migrations表中將出問題的app相關的遷移記錄都刪掉。使用makemigrations,重新將模型生成一個遷移腳本。使用migrate --fake-initial參數(shù),將剛剛生成的遷移腳本,標記為已經(jīng)完成(因為這些模型相對應的表,其實都已經(jīng)在數(shù)據(jù)庫中存在了,不需要重復執(zhí)行了。)可以做其他的映射了。

到此這篇關于Django migrate報錯的解決方案的文章就介紹到這了,更多相關Django migrate報錯內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Django
相關文章:
主站蜘蛛池模板: 欧美视频二区 | 亚洲精品一区二三区不卡 | 免费一区二区三区 | www.888www看片| 日韩电影免费在线观看中文字幕 | 日韩欧美亚洲 | 欧美成视频在线观看 | 国产中文字幕在线 | 在线观看成人小视频 | 成人午夜网站 | 国产精品久久国产愉拍 | 亚洲综合字幕 | 欧美亚洲综合久久 | 91国内精品久久 | 81精品国产乱码久久久久久 | 一区二区免费看 | 国产高清免费在线 | 一区二区久久精品 | 日韩欧美大片在线观看 | 在线一区二区三区 | 午夜一区| 精品啪啪| 成人av网站在线观看 | 国产乱码精品一区二三赶尸艳谈 | 午夜影院在线观看 | 九九伦理电影 | 国产精品久久国产精品 | 91xxx在线观看 | 成人激情视频在线播放 | 在线看一区二区三区 | 国产欧美一区二区三区久久手机版 | 欧美精品一区二区三区在线播放 | 337p日韩| 国产午夜精品久久久 | 一区二区高清在线观看 | 艹逼网 | 国产伦精品一区二区三毛 | 亚洲综合首页 | 成人影院午夜 | 国产三级精品视频 | 久久久夜色精品亚洲 |