如何解决在postgresql jsonb列中查询内部字段
我有一个jsonb列,其结构如下:
{
.....other fields,"a" : {
"b" : {
"c" : "some value",....other fields
}
.....other fields
},...other fields
}
我可以这样查询,属性是表MyTable中的列名:
SELECT * from
MyTable t
WHERE t.properties @> '{"a":{"b":{"c": "some value"}}}';
但是“ c”之前的字段可能会有所不同,即我们可以拥有:
{
.....other fields,"m" : {
"n" : {
"c" : "some value",....other fields
}
.....other fields
},...other fields
}
如何针对这种情况修改查询?
解决方法
如果嵌套始终处于同一级别,则可以使用JSON / Path表达式:
location ^~ /membership/plans {
if ($request_uri ~* "mem_redirect_flow=1"){
set $memcheck 1;
}
if ($request_uri ~* "mem_redirect_flow=2"){
set $memcheck 1;
}
if ($request_uri ~* "mem_redirect_flow=3"){
set $memcheck 1;
}
if ($request_uri ~* "mem_redirect_flow=4"){
set $memcheck 1;
}
.....
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。