gpt4 book ai didi

ruby-on-rails - 简单的 Rails 数组不保存到数组列

转载 作者:数据小太阳 更新时间:2023-10-29 08:31:53 25 4
gpt4 key购买 nike

我正在使用 Rails 4.1.0、Ruby 2.1.0 和 Postgres 9.3.0.0。

我正在尝试将更改保存到一个列,该列是一个 hstores 数组(在 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

一些注意事项:

  1. 购物车在 added_product_hashes 列中使用一个空数组进行初始化
  2. 我将添加的产品存储为哈希值,因为有多种方法可以将产品添加到购物车,并且每种方法都需要自己的逻辑来删除和自定义。
  3. 每个用户都有自己的购物车,以后需要引用它,这就是为什么要像这样将购物车保存到数据库中(我猜不是使用 session 变量)。

知道我做错了什么吗?我没有看到错误:服务器日志记录了 cart.added_product_hashes列更新正确,但更改不会持续存在。

解决方案

正如詹姆斯指出的那样,<<不会将记录标记为脏记录,因为它会就地编辑数组。虽然我没有在数组列中更改 hstores 本身,但似乎除非显式重建属性,否则不会获取对封闭数组的更改。下面的代码解决了这个问题:

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

James 还建议了一种更简洁的特定方法。

最佳答案

参见“New data not persisting to Rails array column on Postgres

ActiveRecord 无法识别数组的更改,因为属性正在就地更新。

你也可以这样做:

cart.added_product_hashes_will_change!

关于ruby-on-rails - 简单的 Rails 数组不保存到数组列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25367072/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com