1

伙计们。

在控制器中发出以下代码块时,生成的 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 类型的列。

其他一切正常。检查了我的代码几十次,没有任何运气。

有什么线索吗?

4

0 回答 0