一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術(shù)及教程分享平臺!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - Django migrate報(bào)錯(cuò)的解決方案

Django migrate報(bào)錯(cuò)的解決方案

2021-11-08 10:49Silent丿丶黑羽 Python

在講解如何解決migrate報(bào)錯(cuò)原因前,我們先要了解migrate做了什么事情,本文就詳細(xì)的介紹migrate使用以及出現(xiàn)問題的解決,感興趣的可以了解一下

前言

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

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

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

問題2:migrate做了什么事情

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

實(shí)戰(zhàn)案例

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

Django migrate報(bào)錯(cuò)的解決方案

接著在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,此時(shí)2個(gè)app目錄中都會出現(xiàn)遷移文件0001_initial.py,此時(shí)數(shù)據(jù)庫中是沒有表的,因?yàn)檫€沒有執(zhí)行遷移命令
接著我們執(zhí)行migrate article,再輸入migrate front,migrate發(fā)現(xiàn)數(shù)據(jù)庫中沒有遷移腳本,那么就會執(zhí)行剛才生成的2個(gè)遷移腳本,將遷移腳本翻譯成SQL語句,然后創(chuàng)建了2張表,執(zhí)行完成后,會將遷移腳本記錄到django_migrations表中,數(shù)據(jù)庫中表結(jié)構(gòu)如下:

Django migrate報(bào)錯(cuò)的解決方案

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

Django migrate報(bào)錯(cuò)的解決方案

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

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

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

Django migrate報(bào)錯(cuò)的解決方案

現(xiàn)在我們來模仿錯(cuò)誤信息內(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),
        ),
    ]

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

Django migrate報(bào)錯(cuò)的解決方案

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

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

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

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

Django migrate報(bào)錯(cuò)的解決方案

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

第一種報(bào)錯(cuò)情況總結(jié)

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

第二種報(bào)錯(cuò)情況

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

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

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

原文鏈接:https://www.cnblogs.com/jiakecong/p/14789389.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美夫妇野外交换hd高清版 | 欧美成人免费观看久久 | 女人把私密部位张开让男人桶 | 91噜噜噜噜色| 无码骚夜夜精品 | 亚洲精品久久啪啪网站成年 | 亚洲乱码尤物193yw在线播放 | 九九热只有精品 | 日本xxx18hd | 亚洲国产视频网站 | 婷婷色六月 | 国外欧美一区另类中文字幕 | tobu8中国在线观看免费视频 | 91精品乱码一区二区三区 | 东方影视欧美天天影院 | 欧美一级裸片又黄又裸 | 亚洲午夜久久久久国产 | 二次元美女脱裤子让男人桶爽 | 手机在线观看网站免费视频 | 美女校花被调教出奶水 | 乌克兰精品摘花处破 | 色综合视频一区二区观看 | www.国产自拍 | 蜜桃久久久亚洲精品成人 | 麻豆亚洲一区 | wwwav视频| 亚洲精品国产AV成人毛片 | 久久99热狠狠色AV蜜臀 | 免费观看国产大片资源视频 | 国产精品女主播大秀在线 | 99热免费在线 | 欧美一级片免费 | 好大好硬好湿好紧h | 国产短视频精品一区二区三区 | 亚洲福利精品电影在线观看 | 男女爆操 | 色噜噜狠狠狠综合曰曰曰88av | 日本在线观看免费观看完整版 | 亚洲国产精品福利片在线观看 | pregnant欧美孕交xxx| 污斗罗大陆 |