如何在MySQL中搜索JSON数组?

时间:2016-03-27 16:33:02

标签: mysql mysql-json

假设我在某些MySQL表中有一个名为 data 的JSON列,此列是一个数组。因此,例如,数据可能包含:

  

[1,2,3,4,5]

现在我想选择所有具有数据列的行,其中一个数组元素大于2.这可能吗?

我尝试了以下内容,但无论数组中的值是什么,似乎总是 true

SELECT * from my_table
WHERE JSON_EXTRACT(data, '$[*]') > 2;

10 个答案:

答案 0 :(得分:9)

SELECT JSON_SEARCH('["1","2","3","4","5"]', 'one', "2") is not null 

是真的

SELECT JSON_SEARCH('["1","2","3","4","5"]', 'one', "6") is not null

是假的

答案 1 :(得分:2)

一种可能的方法是将问题作为字符串匹配来处理。将JSON转换为字符串并匹配。

或者您可以使用JSON_CONTAINS

答案 2 :(得分:2)

我不知道我们是否找到了解决方案。 我发现使用MariaDB可以搜索数组中的路径。例如,在数组[{“id”:1},{“id”:2}]中,我想要找到id等于2的路径。

SELECT JSON_SEARCH('name_field', 'one', 2, null, '$[*].id')
FROM name_table

结果是:

"$[1].id"

星号表示搜索整个数组

答案 3 :(得分:1)

Since MySQL 8有一个名为JSON_TABLE的新功能。

CREATE TABLE my_table (id INT, data JSON);

INSERT INTO my_table VALUES 
  (1, "[1,2,3,4,5]"), 
  (2, "[0,1,2]"), 
  (3, "[3,4,-10]"), 
  (4, "[-1,-2,0]");

SELECT DISTINCT my_table.* 
FROM my_table, JSON_TABLE(data, "$[*]" COLUMNS(nr INT PATH '$')) as ids 
WHERE ids.nr > 2;

+------+-----------------+
| id   | data            |
+------+-----------------+
|    1 | [1, 2, 3, 4, 5] |
|    3 | [3, 4, -10]     |
+------+-----------------+
2 rows in set (0.00 sec)

答案 4 :(得分:1)

您可以使用JSON提取来搜索和选择数据

SELECT data, data->"$.id" as selectdata
FROM table
WHERE JSON_EXTRACT(data, "$.id") = '123'
#ORDER BY c->"$.name";
limit 10 ;

答案 5 :(得分:1)

我结合使用 JSON_EXTRACT 和 JSON_CONTAINS (MariaDB):

SELECT * FROM table WHERE JSON_CONTAINS(JSON_EXTRACT(json_field, '$[*].id'), 11, '$');

答案 6 :(得分:0)

<p *ngIf="!emptyWellcome && !emptyWellcomeEdit" class="paragraph" title="Clique Para Editar" [innerHtml]="welcomeNode | safeHtml"
    (click)="edit(); clickInside($event)">
</p>
<p-editor *ngIf="emptyWellcomeEdit" [(ngModel)]="wellcomeModel" [style]="{'height':'320px'}" (onTextChange)="thereWereChanges=true"
    (click)="clickInside($event)"></p-editor>

结果:“ $ [0] .SongLabels [0] .SongLabelName”

SET @doc = '[{"SongLabels": [{"SongLabelId": "111", "SongLabelName": "Funk"}, {"SongLabelId": "222", "SongLabelName": "RnB"}], "SongLabelCategoryId": "test11", "SongLabelCategoryName": "曲风"}]';
SELECT *,  JSON_SEARCH(@doc, 'one', '%un%', null, '$[*].SongLabels[*].SongLabelName')FROM t_music_song_label_relation;

结果:[“ Funk”,“ RnB”]

答案 7 :(得分:0)

我有类似的问题,可以通过功能搜索

create function searchGT(threshold int, d JSON)
returns int
    begin
        set @i = 0;
        while @i < json_length(d) do
            if json_extract(d, CONCAT('$[', @i, ']')) > threshold then
                return json_extract(d, CONCAT('$[', @i, ']'));
            end if;
            set @i = @i + 1;
        end while;
        return null;
    end;

select searchGT(3, CAST('[1,10,20]' AS JSON));

答案 8 :(得分:0)

您可以按以下方式搜索整数数组:

  JSON_CONTAINS('[1,2,3,4,5]','7','$') Returns: 0
  JSON_CONTAINS('[1,2,3,4,5]','1','$') Returns: 1

您可以按以下方式搜索字符串数组:

  JSON_CONTAINS('["a","2","c","4","x"]','"x"','$') Returns: 1
  JSON_CONTAINS('["1","2","3","4","5"]','"7"','$') Returns: 0

注意:JSON_CONTAINS返回1或0

在您的情况下,您可以使用类似这样的查询进行搜索:

SELECT * from my_table
WHERE JSON_CONTAINS(data, '2', '$');

答案 9 :(得分:0)

这个例子适用于我上面的 mysql 5.7

SET @j = '{"a": [ "8428341ffffffff", "8428343ffffffff", "8428345ffffffff", "8428347ffffffff","8428349ffffffff", "842834bffffffff", "842834dffffffff"], "b": 2, "c": {"d": 4}}';
select JSON_CONTAINS(JSON_EXTRACT(@j , '$.a'),'"8428341ffffffff"','$') => returns 1
             

关于搜索关键字 " 的通知,'"8428341ffffffff"'