我有一个JSONB列,其中包含一组键/值对,其中没有复杂的嵌套结构或数组。钥匙是动态的,我事先不知道。我使用的是PostgreSQL 9.6。
我想做的是使用如下所示的查询来查询JSONB列中的值
ILIKE '%mysearchterm%'它得到了三图指数的很好的支持。我已经使用它们来索引常规文本列,对于这种查询,它非常好地工作,但是我不知道这里如何准确地处理JSONB列。
有没有办法将JSONB列中的所有值(而不是键)转储到trigram索引中?
发布于 2018-08-18 02:17:46
您可以创建一个函数,该函数将数据作为字符串返回:
CREATE OR REPLACE FUNCTION public.jsonb_val_to_string(jsonb)
RETURNS text
LANGUAGE plpgsql
IMMUTABLE
AS $function$
declare x text;
BEGIN
select string_agg(value,' ') into x from jsonb_each_text($1);
return x;
END
$function$然后创建索引:
create index on jason using gin (jsonb_val_to_string(x) gin_trgm_ops);然后使用以下函数进行查询:
explain select * from jason where jsonb_val_to_string(x) ilike '%foo%';当然,您可能希望将string_agg中的分隔符更改为您所知道的将永远不会包含在ilike模式中的内容。
https://dba.stackexchange.com/questions/215101
复制相似问题