1. 程式人生 > 程式設計 >django 模型欄位設定預設值程式碼

django 模型欄位設定預設值程式碼

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

class SitService(models.Model):
 applicationname = models.CharField(max_length=50,primary_key=True)
 ip = models.CharField(max_length=50)
 port = models.IntegerField(default=22) #設定預設值為22
 path = models.CharField(max_length=50)

補充知識:django 設定預設值到SQL

環境:django 1.9.7

背景介紹

django migrate 生成表結構時,預設是不處理default(即欄位的default 是在django 框架層面,沒有到資料庫層面)。當然,如果只用django 來做專案是沒有任何問題的,但是如果同一個庫被不同框架操作,那麼怎麼來管理這些表呢是個問題。

專案前端系統使用tornado,後端管理系統使用django,鑑於這種情況,所以就用django來生成所有的表,但是在實際中,不通過django 插入的資料全都報錯,一檢視,全是預設值沒有填寫的情況。

歷史變化

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

#4800 Field's default value in model isn't passed to SQL

上面的fix已經過時太久,在1.9.7裡面這些都是有的,只是遮蔽了default

詳情

跟蹤除錯發現如下東西

在檔案: 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 方法在呼叫 column_sql,方法時,沒有傳遞引數,skip_default 方法始終返回False

知道了這些後,我們只需要自定義 include_default 的值就好

當資料庫用mysql,longtext and longblob 設定預設值會報錯

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

以上這篇django 模型欄位設定預設值程式碼就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。