Django models文件模型變更錯誤解決
表結構的修改
1、表結構修改后,原來表中已存在的數(shù)據(jù),就會出現(xiàn)結構混亂,makemigrations更新表的時候就會出錯
比如第一次建模型,漏了一個字段,后來補上了。(經常遇到模型字段修改)
重新makemigrations,然后報錯
數(shù)據(jù)庫規(guī)則:除了新建表,如果你再次增加字段,數(shù)據(jù)庫會有一些自動檢測的東西(比如有沒有默認值,是否允許為空)
如果表中已經有數(shù)據(jù),這個字段還是非空的,且沒有設定默認值,后臺檢測不通過就會報錯。
解決方法(有兩種):
1、新增加的字段,設置允許為空。生成表的時候,之前數(shù)據(jù)新增加的字段就會為空。(null=True允許數(shù)據(jù)庫中為空,blank=True允許admin后臺中為空)
2、新增加的字段,設置一個默認值。生成表的時候,之前的數(shù)據(jù)新增加字段就會應用這個默認值(default=None,默認值為空)
刪除0001_initial.py,再次makemigrations
接著再往數(shù)據(jù)庫推送,python3 manage.py migrate
原來是自己在數(shù)據(jù)庫手動添加過,不是通過django方式的。
于是想刪除表,刪了再次執(zhí)行,發(fā)現(xiàn)沒有變化
刪表有風險,可能誤刪其他表,如果表不多,所以還是新建一個庫,環(huán)境干凈(強迫癥啊)
最后完美解決
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- django框架使用views.py的函數(shù)對表進行增刪改查內容操作詳解【models.py中表的創(chuàng)建、views.py中函數(shù)的使用,基于對象的跨表查詢】
- 解決django同步數(shù)據(jù)庫的時候app models表沒有成功創(chuàng)建的問題
- Django如何自定義model創(chuàng)建數(shù)據(jù)庫索引的順序
- Django 根據(jù)數(shù)據(jù)模型models創(chuàng)建數(shù)據(jù)表的實例
- Django model.py表單設置默認值允許為空的操作
- Django獲取model中的字段名和字段的verbose_name方式
- Django Model中字段(field)的各種選項說明
- Django自定義列表 models字段顯示方式
- Django更新models數(shù)據(jù)庫結構步驟
- Django如何批量創(chuàng)建Model
相關文章
python使用aiohttp通過設置代理爬取基金數(shù)據(jù)簡單示例
這篇文章主要為大家介紹了python使用aiohttp通過設置代理爬取基金數(shù)據(jù)簡單示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06python調用百度AI接口實現(xiàn)人流量統(tǒng)計
這篇文章主要介紹了python調用百度AI接口實現(xiàn)人流量統(tǒng)計,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-02Python用requests-html爬取網頁的實現(xiàn)
本文主要介紹了Python用requests-html爬取網頁的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-07-07Pycharm下載pyinstaller報錯:You?should?consider?upgrading?via
這篇文章主要給大家介紹了關于Pycharm下載pyinstaller報錯:You?should?consider?upgrading?via?the?'python?-m?pip?install?--upgrade?pip'?command的解決方法,需要的朋友可以參考下2022-02-02Python word文本自動化操作實現(xiàn)方法解析
這篇文章主要介紹了Python word文本自動化操作實現(xiàn)方法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-11-11Gradio機器學習模型快速部署工具quickstart前篇
這篇文章主要為大家介紹了Gradio機器學習模型快速部署工具quickstart準備原文翻譯,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04