亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

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

Django更新models數(shù)據(jù)庫結構步驟

瀏覽:63日期:2024-10-13 16:01:52

有時候在我們使用Django設計了models中的數(shù)據(jù)庫結構,并且已經(jīng)同步了數(shù)據(jù)庫之后,我們突然想在數(shù)據(jù)表中更新或者增加新的字段,也就是需要修改數(shù)據(jù)庫的結構,會出現(xiàn)以下的問題:

C:UsersAdministratorDesktopWeb開發(fā)Django_Demojkxy>python manage.py makemigrationsYou are trying to add a non-nullable field ’grade’ to student without a default; we can’t do that (the database needs something to populate existing rows).Please select a fix:1) Provide a one-off default now (will be set on all existing rows with a null value for this column)2) Quit, and let me add a default in models.pySelect an option:

就是在我們在models中修改了表的字段后,進行python manage.py makemigrations同步數(shù)據(jù)庫時會出現(xiàn)上面報錯,會導致數(shù)據(jù)庫結構更新失敗

解決方法如下:

第一種方式:先刪除再重構

1、刪除數(shù)據(jù)庫對應的數(shù)據(jù)表

注意:在這里可以不用暴力刪除數(shù)據(jù)表,可以利用django的migrations進行,操作如下:

1.1、首先將自己需要重構的數(shù)據(jù)表類的models注釋掉,然后輸入命令python manage.py makemigrations,這個時候migration會自動記錄刪除數(shù)據(jù)表的操作

Django更新models數(shù)據(jù)庫結構步驟

Django更新models數(shù)據(jù)庫結構步驟

1.2、然后在輸入命令python manage.py migrate,Django會自動將本地對應的數(shù)據(jù)庫進行刪除

Django更新models數(shù)據(jù)庫結構步驟

2、刪除應用當中的migrations文件

3、刪除應用當中的pychace文件

4、刪除db_sqllite文件(若配置數(shù)據(jù)庫為mysql時,可以刪除db_sqllite)

5、建立一個空數(shù)據(jù)庫,命令為python manage.py makemigrations --empty 應用名稱

C:UsersAdministratorDesktopWeb開發(fā)Django_Demojkxy>python manage.py makemigrations --empty bbsMigrations for ’bbs’:bbsmigrations0001_initial.py

6、同步數(shù)據(jù)庫:

python manage.py makemigrationspython manage.py migrate C:UsersAdministratorDesktopWeb開發(fā)Django_Demojkxy>python manage.py makemigrations --empty bbsMigrations for ’bbs’: bbsmigrations0001_initial.py C:UsersAdministratorDesktopWeb開發(fā)Django_Demojkxy>python manage.py makemigrationsMigrations for ’bbs’: bbsmigrations0002_student_testmyfield.py - Create model Student - Create model Testmyfield C:UsersAdministratorDesktopWeb開發(fā)Django_Demojkxy>python manage.py migrateOperations to perform: Apply all migrations: admin, auth, bbs, contenttypes, sessionsRunning migrations: Applying contenttypes.0001_initial... OK Applying auth.0001_initial... OK Applying admin.0001_initial... OK Applying admin.0002_logentry_remove_auto_add... OK Applying contenttypes.0002_remove_content_type_name... OK Applying auth.0002_alter_permission_name_max_length... OK Applying auth.0003_alter_user_email_max_length... OK Applying auth.0004_alter_user_username_opts... OK Applying auth.0005_alter_user_last_login_null... OK Applying auth.0006_require_contenttypes_0002... OK Applying auth.0007_alter_validators_add_error_messages... OK Applying auth.0008_alter_user_username_max_length... OK Applying bbs.0001_initial... OK Applying bbs.0002_student_testmyfield... OK Applying sessions.0001_initial... OK

第二種方式:直接在原結構上更新結構

#出版社class Publisher(models.Model): ’’’出版社數(shù)據(jù)表’’’ id=models.AutoField(primary_key=True) #自增ID主鍵 name=models.CharField(max_length=50,verbose_name=’出版社名稱’,null=False,unique=True) def __str__(self): return ’{},{}’.format(self.id,self.name)

接下來我們需要新增一個字段addr地址

#出版社class Publisher(models.Model): ’’’出版社數(shù)據(jù)表’’’ id=models.AutoField(primary_key=True) #自增ID主鍵 name=models.CharField(max_length=50,verbose_name=’出版社名稱’,null=False,unique=True) addr=models.CharField(max_length=128,verbose_name=’出版社地址’) def __str__(self): return ’{},{}’.format(self.id,self.name,self.addr)

由于我們的數(shù)據(jù)庫的Publisher表本身已經(jīng)有數(shù)據(jù)了,所以我們在進行python manage.py makemigrations會出現(xiàn)以下錯誤:

Django更新models數(shù)據(jù)庫結構步驟

上圖的意思是說addr沒有默認值,無法更新到數(shù)據(jù)庫中,然后給出了兩個選項:

第一是讓你馬上給定一個默認值,然后一次性的把所有addr都寫成這個值

第二是先退出,你自己在models里面去配置默認值

我選擇先退出,在models中加上默認值,在進行makemigrations,這次就會更新成功了!

#出版社class Publisher(models.Model): ’’’出版社數(shù)據(jù)表’’’ id=models.AutoField(primary_key=True) #自增ID主鍵 name=models.CharField(max_length=50,verbose_name=’出版社名稱’,null=False,unique=True) addr=models.CharField(max_length=128,verbose_name=’出版社地址’,default=’成都市動物園’) def __str__(self): return ’{},{}’.format(self.id,self.name,self.addr)

Django更新models數(shù)據(jù)庫結構步驟

讓我們來檢查數(shù)據(jù)庫中的數(shù)據(jù)表:

Django更新models數(shù)據(jù)庫結構步驟

可以看到數(shù)據(jù)結構發(fā)生了變化!

以上這篇Django更新models數(shù)據(jù)庫結構步驟就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Django
相關文章:
主站蜘蛛池模板: 国产黄色三级 | 在线免费观看国产视频 | 免费成人毛片 | 欧美一级亚洲一级 | 国产韩国精品一区二区三区久久 | 一级毛片aaaaaa免费看 | 美女张开腿让男人桶下面 | 狠色狠狠色狠狠狠色综合久久 | 五月六月伊人狠狠丁香网 | 国产成人教育视频在线观看 | 欧美在线成人午夜影视 | 成人亚洲欧美综合 | 欧美视频在线观 | 直接在线观看的三级网址 | 久草最新网址 | 男人天堂视频网站 | 全部免费毛片免费播放 | 69精品免费视频 | 欧美亚洲日本国产 | 国产网曝手机视频在线观看 | 亚洲欧美日韩三级 | 久久99国产精一区二区三区! | 黄色激情网站 | 国产成人免费网站在线观看 | 国内精品久久久久不卡 | 亚洲黄色三级视频 | 欧美一级一极性活片免费观看 | 日韩美女视频一区 | 97在线免费视频 | 99久久国产综合精品五月天 | 亚洲精品高清国产一线久久97 | 2020毛片 | 亚洲欧美日韩中文字幕在线 | 亚洲欧美激情在线 | 亚洲无总热门 | 99久久国产免费中文无字幕 | 日朝欧美亚洲精品 | 欧美成人高清性色生活 | 男人添女人下面免费毛片 | 欧美性欲视频 | 日本欧美一区二区三区在线 |