簡體   English   中英

在 MySQL 中,json_search 因 json_array 中的 integer 元素而失敗

[英]In MySQL, json_search fail with integer element in json_array

我有一個 json_array [1, 2, 3, 3, 3],我想知道元素 '3' 的數量。

例如,

json_search('[1, 2, 3, 3, 3]', 'all', 3) return null;
json_search('["1", "2", "3", "3", "3"]', 'all', '3') return ["$[2]", "$[3]", "$[4]"];

所以,

json_length(json_search('[1, 2, 3, 3, 3]', 'all', 3)) return null;

我要 3

我一直在尋找一整天,但我不知道解決方案並尋求幫助。

這里的一個選項,假設您只有一個 JSON 整數的頂級數組,將使用正則表達式替換技巧來計算 3 的數量:

WITH yourTable AS (
    SELECT '[1, 2, 3, 3, 3]' AS array
)

SELECT
    LENGTH(array) - LENGTH(REGEXP_REPLACE(array, '\\b3\\b', '')) AS num_3
FROM yourTable;

這將返回 3 作為長度,這是正確的。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM