溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

django模型字段設(shè)置默認(rèn)值的方法

發(fā)布時(shí)間:2020-07-16 15:59:04 來源:億速云 閱讀:598 作者:小豬 欄目:開發(fā)技術(shù)

這篇文章主要講解了django模型字段設(shè)置默認(rèn)值的方法,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。

我就廢話不多說了,大家還是直接看代碼吧~

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ù)庫層面)。當(dāng)然,如果只用django 來做項(xiàng)目是沒有任何問題的,但是如果同一個(gè)庫被不同框架操作,那么怎么來管理這些表呢是個(gè)問題。

項(xiàng)目前端系統(tǒng)使用tornado,后端管理系統(tǒng)使用django, 鑒于這種情況,所以就用django來生成所有的表,但是在實(shí)際中,不通過django 插入的數(shù)據(jù)全都報(bào)錯(cuò),一查看,全是默認(rèn)值沒有填寫的情況。

歷史變化

#470 "default" values should be expressed in SQL schema

#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ù)庫用mysql, longtext and longblob 設(shè)置默認(rèn)值會(huì)報(bào)錯(cuò)

include_default = False if sql in ['longtext', 'longblob'] else True

看完上述內(nèi)容,是不是對(duì)django模型字段設(shè)置默認(rèn)值的方法有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI