postgresql在where子句中使用json子元素
发布时间:2020-12-13 16:33:26 所属栏目:百科 来源:网络整理
导读:这可能是一个非常基本的问题,但我无法在网上找到任何内容. 如果我创建一个示例表: create table dummy ( id int not null,data json ); 然后,如果我使用以下查询查询表: select * from dummy where data-'x' = 10; 现在,由于表中没有记录,并且在任何记录中
这可能是一个非常基本的问题,但我无法在网上找到任何内容.
如果我创建一个示例表: create table dummy ( id int not null,data json ); 然后,如果我使用以下查询查询表: select * from dummy where data->'x' = 10; 现在,由于表中没有记录,并且在任何记录中都没有“x”的属性,所以应该返回零结果. 但是我收到以下错误: postgres=# select * from dummy where data->'x' = 10; ERROR: operator does not exist: json = integer LINE 1: select * from dummy where data->'x' = 10; 但以下查询工作: select * from dummy where cast(data->>'x' as integer) = 10; 我在这里缺少某些东西,或者是类型转换是从json字段获得整数值的唯一方法?如果是这样,当数据变得非常大时,不会影响性能?
你是正确的,类型转换是从json字段读取整数值的唯一方法.
Postgres允许您对包括转换的索引功能进行索引,因此下面的索引将允许您快速检索data->> x具有某个整数值的所有行 CREATE INDEX dummy_x_idx ON dummy(cast("data"->>'x' AS int)) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |