微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ruby-on-rails – 如何使用ActiveRecord仅选择存储在Postgres中的json的一部分

假设我有一个模型User,它有一个json类型的字段叫做settings.我们假设这个字段大致如下:
{
  color: 'red',language: 'English',subitems: 
    {
      item1: true,item2: 43,item3: ['foo','bar','baz']
    }
}

如果我执行User.select(:settings),我将获得每个用户的所有设置.但我想只为用户提供语言.我试过两个:

User.select("settings -> 'language'")

User.select("settings ->> 'language'")

但这只是返回空对象:

[#<User:0x007f381fa92208 id: nil>,...]

这是可能吗?如果是 – 我可以只使用json做或者我需要切换到jsonb吗?

解决方法

尝试User.select(“设置 – >’语言’作为user_language”). 结果关系中的每个对象都应响应user_language.

原文地址:https://www.jb51.cc/ruby/264514.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐