加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – Ruby on Rails:序列化Hash非常慢

发布时间:2020-12-17 02:32:58 所属栏目:百科 来源:网络整理
导读:我有一个名为“搜索”的简单模型,用于存储搜索.它捕获URL参数并将它们存储在属性:search_criteria中,该序列被序列化为哈希: serialize :search_criteria,Hash 这一切都很完美,但它表现得非常糟糕.仅对于5个对象,以下语句大约需要0.2秒. start = Time.nowSa
我有一个名为“搜索”的简单模型,用于存储搜索.它捕获URL参数并将它们存储在属性:search_criteria中,该序列被序列化为哈希:

serialize :search_criteria,Hash

这一切都很完美,但它表现得非常糟糕.仅对于5个对象,以下语句大约需要0.2秒.

start = Time.now
SavedSearch.all.map(&:search_criteria)
puts Time.now - start

但是,如果我删除序列化行(使search_criteria返回一个字符串),则语句只需0.002秒.对于反序列化Hash,这是2个数量级的差异!

这里发生了什么事?

Rails.version = 3.2.8
Ruby 1.9.3p194(2012-04-20修订版35410)[x86_64-linux]

解决方法

Active Record可能会产生大量开销,因此看起来像是矫枉过正.当它循环时,它实例化SavedSearch中的每个对象,然后评估它需要创建的属性,然后它执行映射.

如果你知道确切的结构,它似乎存储在’search_criteria’中,那么只需将它存储在文本属性的YAML中.那应该快得多.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读