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

django 模型字段設置默認值代碼

瀏覽:10日期:2024-09-25 14:17:34

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

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.pyline: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 模型字段設置默認值代碼就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
国产综合久久一区二区三区