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

ruby-on-rails – 如何使用ActiveRecord仅选择存储在Postgres中

发布时间:2020-12-16 23:29:08 所属栏目:百科 来源:网络整理
导读:假设我有一个模型User,它有一个json类型的字段叫做settings.我们假设这个字段大致如下: { color: 'red',language: 'English',subitems: { item1: true,item2: 43,item3: ['foo','bar','baz'] }} 如果我执行User.select(:settings),我将获得每个用户的所有
假设我有一个模型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.

(编辑:李大同)

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

    推荐文章
      热点阅读