婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Django migrate報錯的解決方案

Django migrate報錯的解決方案

熱門標(biāo)簽:如何申請400電話費用 沈陽人工外呼系統(tǒng)價格 沈陽外呼系統(tǒng)呼叫系統(tǒng) 武漢外呼系統(tǒng)平臺 沈陽防封電銷卡品牌 富錦商家地圖標(biāo)注 外呼系統(tǒng)哪些好辦 江西省地圖標(biāo)注 池州外呼調(diào)研線路

前言

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

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

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

問題2:migrate做了什么事情

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

實戰(zhàn)案例

當(dāng)我們了解清楚migrate的作用后,我們來看一個案例
首先我們創(chuàng)建一個項目orm_migrations_demo,接著創(chuàng)建2個app應(yīng)用frontarticle,代碼結(jié)構(gòu)如下圖


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

# front.models.py
class Article(models.Model):
    name = models.CharField(max_length=200)

# article.models.py
class FrontUser(models.Model):
    name = models.CharField(max_length=200)

接著在settings.pyINSTALL_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ù)庫中表結(jié)構(gòu)如下:

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


接下來我們在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個遷移腳本


現(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中的字段:


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

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

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

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


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

第一種報錯情況總結(jié)

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

第二種報錯情況

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

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

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

您可能感興趣的文章:
  • 解決django migrate報錯ORA-02000: missing ALWAYS keyword
  • Django-migrate報錯問題解決方案

標(biāo)簽:阿里 呂梁 銅川 株洲 潛江 常德 通遼 黑龍江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Django migrate報錯的解決方案》,本文關(guān)鍵詞  Django,migrate,報,錯的,解決方案,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Django migrate報錯的解決方案》相關(guān)的同類信息!
  • 本頁收集關(guān)于Django migrate報錯的解決方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 织金县| 会东县| 河间市| 东乌珠穆沁旗| 锡林浩特市| 克拉玛依市| 萍乡市| 益阳市| 伊通| 庆安县| 涪陵区| 固阳县| 内乡县| 德安县| 吉安县| 吴川市| 昭觉县| 鲁甸县| 望都县| 岳阳县| 承德市| 吴忠市| 周至县| 阜新| 红河县| 巍山| 资源县| 密山市| 怀集县| 贵溪市| 延川县| 郧西县| 女性| 略阳县| 柳河县| 翁源县| 公主岭市| 祁连县| 乐亭县| 抚宁县| 彩票|