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 解决方法
Active Record可能会产生大量开销,因此看起来像是矫枉过正.当它循环时,它实例化SavedSearch中的每个对象,然后评估它需要创建的属性,然后它执行映射.
如果你知道确切的结构,它似乎存储在’search_criteria’中,那么只需将它存储在文本属性的YAML中.那应该快得多. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |