django 模型字段設(shè)置默認(rèn)值代碼
我就廢話不多說了,大家還是直接看代碼吧~
class SitService(models.Model): applicationname = models.CharField(max_length=50,primary_key=True) ip = models.CharField(max_length=50) port = models.IntegerField(default=22) #設(shè)置默認(rèn)值為22 path = models.CharField(max_length=50)
補(bǔ)充知識(shí):django 設(shè)置默認(rèn)值到SQL
環(huán)境:django 1.9.7
背景介紹
django migrate 生成表結(jié)構(gòu)時(shí),默認(rèn)是不處理default(即字段的default 是在django 框架層面,沒有到數(shù)據(jù)庫(kù)層面)。當(dāng)然,如果只用django 來做項(xiàng)目是沒有任何問題的,但是如果同一個(gè)庫(kù)被不同框架操作,那么怎么來管理這些表呢是個(gè)問題。
項(xiàng)目前端系統(tǒng)使用tornado,后端管理系統(tǒng)使用django, 鑒于這種情況,所以就用django來生成所有的表,但是在實(shí)際中,不通過django 插入的數(shù)據(jù)全都報(bào)錯(cuò),一查看,全是默認(rèn)值沒有填寫的情況。
歷史變化
#4800 Field's default value in model isn't passed to SQL
上面的fix已經(jīng)過時(shí)太久,在1.9.7里面這些都是有的,只是屏蔽了default
詳情
跟蹤調(diào)試發(fā)現(xiàn)如下東西
在文件: django/db/backends/base/schema.py line:128
column_sql 方法有如下代碼:
def column_sql(self, model, field, include_default=False): ... include_default = include_default and not self.skip_default(field) if include_default: default_value = self.effective_default(field) if default_value is not None: if self.connection.features.requires_literal_defaults: # Some databases can't take defaults as a parameter (oracle) # If this is the case, the individual schema backend should # implement prepare_default sql += " DEFAULT %s" % self.prepare_default(default_value) else: sql += " DEFAULT %s" params += [default_value] ...
同文件 create_model 方法在調(diào)用 column_sql,方法時(shí),沒有傳遞參數(shù),skip_default 方法始終返回False
知道了這些后,我們只需要自定義 include_default 的值就好
當(dāng)數(shù)據(jù)庫(kù)用mysql, longtext and longblob 設(shè)置默認(rèn)值會(huì)報(bào)錯(cuò)
include_default = False if sql in ['longtext', 'longblob'] else True
以上這篇django 模型字段設(shè)置默認(rèn)值代碼就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
python 使用正則表達(dá)式按照多個(gè)空格分割字符的實(shí)例
今天小編就為大家分享一篇python 使用正則表達(dá)式按照多個(gè)空格分割字符的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-12-12python實(shí)現(xiàn)簡(jiǎn)單井字棋游戲
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)簡(jiǎn)單井字棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03簡(jiǎn)單的Python人臉識(shí)別系統(tǒng)
這篇文章主要介紹了Python人臉識(shí)別系統(tǒng)的實(shí)現(xiàn),文中講解非常詳細(xì),代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07Jupyter導(dǎo)入自定義模塊及導(dǎo)入后TypeError錯(cuò)誤問題及解決
這篇文章主要介紹了Jupyter導(dǎo)入自定義模塊及導(dǎo)入后TypeError錯(cuò)誤問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01python中的split()函數(shù)和os.path.split()函數(shù)使用詳解
今天小編就為大家分享一篇python中的split()函數(shù)和os.path.split()函數(shù)使用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12django多個(gè)APP的urls設(shè)置方法(views重復(fù)問題解決)
今天小編就為大家分享一篇django多個(gè)APP的urls設(shè)置方法(views重復(fù)問題解決),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-07-07基于循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)的古詩(shī)生成器
這篇文章主要為大家詳細(xì)介紹了基于循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)的古詩(shī)生成器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03- 這篇文章主要為大家介紹了python中selenium模塊的安裝和配置環(huán)境變量教程、提取數(shù)據(jù)操作、無頭模式,有需要的朋友可以借鑒參考下,希望能夠?qū)Υ蠹矣兴鶐椭?/div> 2022-10-10
最新評(píng)論