在早期版本的Rails中,可以将动态属性添加到模型中,而无需使用SQL列。以下代码适用于4.0之前的版本。
drow = dtab1.drows.create()
drow.write_attribute('value1', 'xxx')
drow.write_attribute('value2', 'yyy')
drow.write_attribute('value3', 'zzz')
但是现在在v5中我得到了:
ActiveModel::MissingAttributeError: can't write unknown attribute `value1`
现在有什么办法吗?
其他答案提出了预定义的访问器或将动态字段替换为“用户变量”哈希,但这对我的情况不起作用。它们需要真正地动态,在运行时创建并被视为模型的一部分。
答案 0 :(得分:2)
write_attribute方法更新基础表中的属性。由于您的新属性是动态的,并且与模型表中的字段不匹配,因此难怪它不起作用。
要动态添加属性,您需要先声明它,然后像常规属性一样调用setter。例如:
attr_name = 'value1'
# Declaring attr_accessor: attr_name
drow.instance_eval { class << self; self end }.send(:attr_accessor, attr_name)
drow.send(attr_name + '=', 'xxx') # setter
drow.send(attr_name) # getter
该属性将保存到实例变量@value1
。
保存动态属性的另一种方法是直接更改该变量,而无需声明属性访问器:
drow.instance_variable_set("@#{attr_name}".to_sym, 'xxx') # setter
drow.instance_variable_get("@#{attr_name}".to_sym) # getter