Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/json/13.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
选择文本PostgreSQL数组中的数据字段json_Json_Postgresql - Fatal编程技术网

选择文本PostgreSQL数组中的数据字段json

选择文本PostgreSQL数组中的数据字段json,json,postgresql,Json,Postgresql,我在PostgreSQL 9.3中有一个带有json字段的表books CREATE TABLE books ( id integer, data json ); 一排排的桌子 我需要在field data表的field author json中执行select 例如: 从数据->>'author'='Bob'或数据->>'author'='Xavier'的书籍中选择* 有可能吗 谢谢好的,我现在明白你的问题了。答案很简单,关于你如何设置东西 select * from

我在PostgreSQL 9.3中有一个带有json字段的表books

CREATE TABLE books ( 
    id integer, 
    data json 
);
一排排的桌子

我需要在field data表的field author json中执行select

例如:

从数据->>'author'='Bob'或数据->>'author'='Xavier'的书籍中选择*

有可能吗


谢谢

好的,我现在明白你的问题了。答案很简单,关于你如何设置东西

select * from books where data->>'author' = 'Bob' or data->>'author' = 'Xavier'
->>不起作用的原因是字段“author”不是string类型,它实际上是array类型。因此,使用>>时,需要指定所需数组的元素。看这里:

编辑:通读这篇文章,它将帮助您了解如何访问JSON数据字段的不同部分。

你看过吗:?@pmac89是的,我看到了,我试过从书中选择*数据>>“作者”=“鲍勃”;但是不要工作。在字段名称JSON中,请参见选择*FROM books WHERE data->>“name”=“Book the First”;我将->>更改为>>为什么您试图将其从->>更改为>>?我知道>>在json中查找文本数组,因为->>不起作用。我尝试从数据>>{author,Bob}但不起作用的书籍中选择*。select命令正确吗?不确定。我的服务器只有PSQL版本9.2,SQL Fiddle也不适合我。也许这会有所帮助:看看那个奇怪的。我必须记录:3{a:2,b:[c,d]}和4{a:1,b:{c:d,e:true}。此SELECT*FROM json_测试,其中数据>>'{b,c}'='d'返回记录3,但在执行SELECT*FROM json_测试时,其中数据>>'{b}'='d'不是结果记录3。