欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2021年05月20日 16:10:44   作者:Silent丿丶黑羽  
在講解如何解決migrate報(bào)錯(cuò)原因前,我們先要了解migrate做了什么事情,本文就詳細(xì)的介紹migrate使用以及出現(xiàn)問(wèn)題的解決,感興趣的可以了解一下

前言

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

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

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

問(wèn)題2:migrate做了什么事情

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

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

當(dāng)我們了解清楚migrate的作用后,我們來(lái)看一個(gè)案例
首先我們創(chuàng)建一個(gè)項(xiàng)目orm_migrations_demo,接著創(chuàng)建2個(gè)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注冊(cè)

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

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

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


接下來(lái)我們?cè)?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,會(huì)在項(xiàng)目中生成遷移文件0002_article_content.py,接著執(zhí)行migrate article,執(zhí)行遷移腳本,此時(shí)數(shù)據(jù)庫(kù)中表django_migrations有3個(gè)遷移腳本


現(xiàn)在我們來(lái)模仿錯(cuò)誤信息內(nèi)容,我們將數(shù)據(jù)庫(kù)中django_migrations表中的0002_article_content這行記錄刪除,然后我們來(lái)看下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中的字段:


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

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

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

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


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

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

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

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

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

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

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

相關(guān)文章

  • numpy模塊中axis的理解與使用

    numpy模塊中axis的理解與使用

    而在numpy中有很多的函數(shù)都涉及到axis,numpy中的軸axis是很重要的,許多numpy的操作根據(jù)axis的取值不同,作出的操作也不相同,這篇文章主要給大家介紹了關(guān)于numpy模塊中axis的理解與使用的相關(guān)資料,需要的朋友可以參考下
    2022-03-03
  • Python函數(shù)基礎(chǔ)實(shí)例詳解【函數(shù)嵌套,命名空間,函數(shù)對(duì)象,閉包函數(shù)等】

    Python函數(shù)基礎(chǔ)實(shí)例詳解【函數(shù)嵌套,命名空間,函數(shù)對(duì)象,閉包函數(shù)等】

    這篇文章主要介紹了Python函數(shù)基礎(chǔ),結(jié)合實(shí)例形式詳細(xì)分析了函數(shù)嵌套,命名空間,函數(shù)對(duì)象,閉包函數(shù)等相關(guān)概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下
    2019-03-03
  • 利用Python編寫(xiě)一個(gè)簡(jiǎn)單的緩存系統(tǒng)

    利用Python編寫(xiě)一個(gè)簡(jiǎn)單的緩存系統(tǒng)

    今天來(lái)做一個(gè)最簡(jiǎn)單的例子,利用寫(xiě)一個(gè)最簡(jiǎn)單的緩存系統(tǒng),以key``value的方式保持?jǐn)?shù)據(jù),并且需要將內(nèi)容中的數(shù)據(jù)落地到文件,以便下次啟動(dòng)的時(shí)候,將文件的內(nèi)容加載進(jìn)內(nèi)存中來(lái),感興趣的可以了解一下
    2023-04-04
  • Python中的連接符(+、+=)示例詳解

    Python中的連接符(+、+=)示例詳解

    Python 中可使用 + 進(jìn)行字符串的連接操作,這個(gè)相信大家都知道,其實(shí)Python中的連接符還有+=,下面這篇文章主要介紹了Python中的連接符(+、+=),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-01-01
  • 使用python實(shí)現(xiàn)語(yǔ)音文件的特征提取方法

    使用python實(shí)現(xiàn)語(yǔ)音文件的特征提取方法

    今天小編就為大家分享一篇使用python實(shí)現(xiàn)語(yǔ)音文件的特征提取方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • 詳解python路徑拼接os.path.join()函數(shù)的用法

    詳解python路徑拼接os.path.join()函數(shù)的用法

    os.path.join()函數(shù):連接兩個(gè)或更多的路徑名組件。這篇文章主要介紹了python路徑拼接os.path.join()函數(shù)的用法,需要的朋友可以參考下
    2019-10-10
  • Python實(shí)現(xiàn)暴力匹配算法(字符串匹配)

    Python實(shí)現(xiàn)暴力匹配算法(字符串匹配)

    本文主要介紹了Python實(shí)現(xiàn)暴力匹配算法,其主要思想是逐個(gè)字符地比較文本串和模式串,從文本串的每個(gè)可能的起始位置開(kāi)始,依次檢查是否有匹配的子串,下面就來(lái)介紹 一下如何實(shí)現(xiàn)
    2023-09-09
  • Python實(shí)現(xiàn)批量分割PDF文件

    Python實(shí)現(xiàn)批量分割PDF文件

    這篇文章主要為大家詳細(xì)介紹了使用Python進(jìn)行批量分割PDF文件的相關(guān)方法,我們將從架構(gòu)設(shè)計(jì)入手,逐步講解代碼實(shí)現(xiàn)的過(guò)程,希望對(duì)大家有所幫助
    2023-11-11
  • 使用Python實(shí)現(xiàn)管理系統(tǒng)附源碼

    使用Python實(shí)現(xiàn)管理系統(tǒng)附源碼

    這篇文章主要為大家介紹了Python實(shí)現(xiàn)管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-01-01
  • python pymysql庫(kù)的常用操作

    python pymysql庫(kù)的常用操作

    這篇文章主要介紹了python pymysql庫(kù)的常用操作,幫助大家更好的利用python操作數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2020-10-10

最新評(píng)論