如何在MySQL中搜索JSON数组?

27 mysql mysql-json

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

[1,2,3,4,5]

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

我尝试了以下内容,但无论数组中的值如何,似乎总是如此:

SELECT * from my_table
WHERE JSON_EXTRACT(data, '$[*]') > 2;
Run Code Online (Sandbox Code Playgroud)

小智 43

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

  JSON_CONTAINS('[1,2,3,4,5]','7','$') Returns: 0
  JSON_CONTAINS('[1,2,3,4,5]','1','$') Returns: 1
Run Code Online (Sandbox Code Playgroud)

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

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

注意:JSON_CONTAINS 返回 1 或 0

在您的情况下,您可以使用如下查询进行搜索:

SELECT * from my_table
WHERE JSON_CONTAINS(data, '2', '$');
Run Code Online (Sandbox Code Playgroud)

  • 这根本没有回答问题,我们需要所有大于 2 的值,而不是等于 2 的值 (8认同)
  • 省略“$”也可以。 (4认同)

小智 17

从 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)
Run Code Online (Sandbox Code Playgroud)


小智 13

SELECT JSON_SEARCH('["1","2","3","4","5"]', 'one', "2") is not null 
Run Code Online (Sandbox Code Playgroud)

是真的

SELECT JSON_SEARCH('["1","2","3","4","5"]', 'one', "6") is not null
Run Code Online (Sandbox Code Playgroud)

是假的

  • 为什么我不能这样做?`SELECT JSON_SEARCH('[1,2,3,4,5]', 'one', 1) 不为空` (4认同)

Rod*_*ira 13

我使用 JSON_EXTRACT 和 JSON_CONTAINS (MariaDB) 的组合:

SELECT * FROM table WHERE JSON_CONTAINS(JSON_EXTRACT(json_field, '$[*].id'), 11, '$');
Run Code Online (Sandbox Code Playgroud)


小智 5

我不知道我们是否找到了解决方案。我用 MariaDB 找到了一种在数组中搜索路径的方法。例如,在 array 中[{"id":1}, {"id":2}],我想找到 id 等于 2 的路径。

SELECT JSON_SEARCH('name_field', 'one', 2, null, '$[*].id')
FROM name_table
Run Code Online (Sandbox Code Playgroud)

结果是:

"$[1].id"
Run Code Online (Sandbox Code Playgroud)

星号表示搜索整个数组


Moh*_*rab 2

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

或者您可以使用JSON_CONTAINS