環境:django 1.9.7
背景介紹
django migrate 生成表結構時,預設是不處理default(即欄位的default 是在django 框架層面,沒有到資料庫層面)。當然,如果只用django 來做專案是沒有任何問題的,但是如果同一個庫被不同框架操作,那麼怎麼來管理這些表呢是個問題。
專案前端系統使用tornado,後端管理系統使用django, 鑑於這種情況,所以就用django來生成所有的表,但是在實際中,不通過django 插入的資料全都報錯,一檢視,全是預設值沒有填寫的情況。
歷史變化
-
上面的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