我正在使用 Rails 4.1.0、Ruby 2.1.0 和 Postgres 9.3.0.0。
我正在尝试将更改保存到一个列,该列是一个 hstore 数组(用 ruby 的说法是一个哈希数组)。
这是产品模型中的(简化的)代码,用于保存更改:
def add_to_cart_with_credits(cart)
cart.added_product_hashes << {"id" => self.id.to_s, "method" => "credits"}
# For some reason, this isn't saving (without the exclamation, as well)
cart.save!
end
一些值得注意的事情:
- 购物车初始化时,added_product_hashes 列中包含一个空数组
- 我将添加的产品存储为哈希值,因为有多种方法可以将产品添加到购物车,并且每种方法都需要自己的逻辑来删除和自定义。
- 每个用户都有自己的购物车,并且需要稍后引用它,这就是为什么购物车像这样保存到数据库中(我猜不是使用 session 变量)。
你知道我做错了什么吗?我没有看到错误:服务器日志注意到 cart.added_product_hashes
列正确更新,但更改不会持续。
解决方案
正如詹姆斯指出的那样,<<
不会将记录标记为脏记录,因为它会就地编辑数组。虽然我没有更改数组列中的 hstore 本身,但除非显式重建属性,否则不会拾取对封闭数组的更改。下面的代码解决了这个问题:
def add_to_cart_with_credits(cart)
cart.added_product_hashes = cart.added_product_hashes + [{"id" => self.id.to_s, "method" => "credits"}]
# Now we're all good to go!
cart.save!
end
詹姆斯还建议了一种更简洁的特定方法。
最佳答案
参见“New data not persisting to Rails array column on Postgres”
ActiveRecord 无法识别对数组的更改,因为属性正在就地更新。
你也可以这样做:
cart.added_product_hashes_will_change!
关于ruby-on-rails - Simple Rails 数组未保存到数组列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25367072/