假设我有一个模型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.