我正在将Rails应用程序从4.1.16版本升级到5.2.3
我有一列没有空约束,默认值为0
schema.rb:
t.integer wait_time_minutes default: 0, null: false
相关表格包含以下内容:
= f.select :wait_time_minutes, [15, 30, 45, 60, 90, 120], { include_blank: true }, class: 'form-control'
在提交此表单时未选择任何值时,将在参数中提交以下内容:
"wait_time_minutes"=>""
它尝试使用nil更新列:
UPDATE "table_name" SET "wait_time_minutes" = $1, "updated_at" = $2 WHERE "table_name"."id" = $3 ["wait_time_minutes", nil], ["updated_at", "2019-06-23 05:32:28.368640"], ["id", 1445]]
由于该列没有null约束,因此会引发以下异常:
PG::NotNullViolation - ERROR: null value in column "wait_time_minutes" violates not-null constraint
但这不是以前的工作方式。在Rails 4.1.16中效果很好。
如何解决此问题?在我的应用程序的大多数地方都存在这个问题。谢谢。
答案 0 :(得分:0)
一种解决方案是使用before_save
# model.rb
before_save do
self.wait_time_minutes ||= 0
end
如果您不熟悉||=
,这是常见的Ruby技巧,用于实例化尚未设置的变量。