web-dev-qa-db-ja.com

MySQLでJSON配列を検索する方法は?

MySQLテーブルにdataというJSON列があり、この列が単一のarrayであるとします。したがって、たとえば、データには次のものが含まれます。

[1,2,3,4,5]

ここで、配列要素の1つが2より大きいデータ列を持つすべての行を選択します。これは可能ですか?

私は次を試しましたが、配列の値に関係なく常にtrueであるようです:

SELECT * from my_table
WHERE JSON_EXTRACT(data, '$[*]') > 2;
24
user1011792
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

偽です

11
JONG MIN IM

可能な方法は、文字列の一致として問題に対処することです。 JSONを文字列に変換して一致させます。

または、 JSON_CONTAINS を使用できます。

3

解決策が見つかったかどうかはわかりません。 MariaDBで、配列内のパスを検索する方法を見つけました。たとえば、配列[{"id":1}、{"id":2}]で、IDが2のパスを検索します。

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

結果は次のとおりです。

"$[1].id"

アスタリスクは、配列全体を検索することを示します

3
Carlos 2V

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)
2
user2458995

JSON抽出を使用してデータを検索および選択できます

SELECT data, data->"$.id" as selectdata
FROM table
WHERE JSON_EXTRACT(data, "$.id") = '123'
#ORDER BY c->"$.name";
limit 10 ;
1
Justin J
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;

結果: "$ [0] .SongLabels [0] .SongLabelName"

SELECT song_label_content->'$[*].SongLabels[*].SongLabelName' FROM t_music_song_label_relation;

結果:["Funk"、 "RnB"]

0
Tom Hu