伙计们。
在控制器中发出以下代码块时,生成的 SQL 不包含模型的一列/属性:
dev_total = DeviceTotal.where(time_stamp: @time_stamp).first_or_create {|dt|
dt.dev_utc = @utc,
dt.value = @grand_total,
dt.production = @net_weight,
dt.device_id = @device.id,
dt.var = @device.variable.symbol
}
生成的 SQL:
INSERT INTO "device_totals" ("created_at", "device_id", "production", "time_stamp",
"updated_at", "value", "var") VALUES ($1, $2, $3, $4, $5, $6, $7)
RETURNING "id" [["created_at", Wed, 09 Oct 2013 22:54:04 UTC +00:00],
["device_id", 1], ["production", 80.38], ["time_stamp", Wed, 09 Oct 2013 22:53:59
UTC +00:00], ["updated_at", Wed, 09 Oct 2013 22:54:04 UTC +00:00], ["value",
847.25], ["var", "FRL"]]
可以看到,“dev_utc”列不包含在 INSERT 命令中。所有其他属性都保存到数据库中。这是一个 BigInt 类型的列。
其他一切正常。检查了我的代码几十次,没有任何运气。
有什么线索吗?