繁体   English   中英

使用ActiveRecord查询哈希的嵌套数组中是否存在键

[英]Querying a nested array of hashes for existence of a key in jsonb postgres with activerecord

我在postgres中使用jsonb数据类型来存储模型的各种变量设置。

使用散列似乎很简单。

如果我创建:

Model.create(settings:{a:"b", c:"d"})
Model.where("settings -> 'a' ? 'b'") #or
=> Model...
Model.where("settings -> 'c' ? 'd'") #or if I just want to check the keys
=> Model...
Model.where("settings ? 'a'")
=> Model...

如果我使用多个键来做一些更复杂的事情:

Model.create(settings:{a:{b:"c", d:"e"}})

Model.where("settings -> 'a' ? 'b' ") #or
=> Model...
Model.where("settings -> 'a' ? 'd' ")
=> Model...

同样地

现在,如果将数组放在顶层,则可以执行以下操作:

Model.create(settings:["a","b"])
Model.where("settings ? "a")
=> Model...

并返回对象。

并带有嵌套数组。

Model.create(settings:{a:["a","b"]})
Model.where("settings -> 'a' ? 'a'")
=> Model...
Model.where("settigns -> 'a' ? :v", v: 'a')
=> Model...

但是,一旦我将任何更复杂的东西放入该数组中,我似乎就再也找不到匹配了。

Model.create(settings:[{a:"b"}, {c:"d"}])
Model.where("settings ? :v", v: {a:"b"})
=> []
Model.create(settings:{a:[{b:"c"}, {d:"e"}]})
Model.where("settings -> 'a' ? :v", v: {b:"c"})
=> []

都无法返回对象。

我想查询一个嵌套数组的元素以了解它们包含的哈希中是否有某些键,但是我无法解决这个问题。 我显然在语法上缺少某些东西,但是我无法弄清楚它是什么。

在这种情况下, Model.create(settings:[{a:"b"}, {c:"d"}])

您可以这样查询: Model.where("settings @> ?", {a: "b"}.to_json)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM