1

这是一个示例表:

id, json_txt
1, [5,18,23,50]
2, []
3, [4,5,12,18,22]
4, [18,22,50]
5, [3,12,70]

我想从json_txt其他行中的第 3 行获取匹配数的总和。

以下是每一行的计数结果:

1 - 2 matches (5 and 18)
2 - 0 matches
3 - 5 matches (it's the row being searched for)
4 - 2 matches (18 and 22)
5 - 1 match (12)

这是我设法得到的:

SELECT * FROM my_table WHERE JSON_CONTAINS(json_txt, '[4,5,12,18,22]', '$')

但这只是找到匹配的行,而不是计算每行中的匹配数:/

4

1 回答 1

0

首先,information_schema.tables用于行生成以确定索引值作为JSON_EXTRACT()函数的第二个参数以及ROW_NUMBER()可用于 DB 版本 10.2+ 的窗口函数,JSON_LENGTH()函数用于确定具有最大长度的数组,以便比较其中的每个元素id 值等于 3 的数组的每个数组:

WITH t AS
(
 SELECT t.id, JSON_EXTRACT(json_txt, CONCAT('$[', rn - 1, ']')) AS elm
   FROM (SELECT ROW_NUMBER() OVER(ORDER BY 1) AS rn
           FROM information_schema.tables) i
          CROSS JOIN tab t
          WHERE rn <= (SELECT MAX(JSON_LENGTH(json_txt)) FROM tab)
)
SELECT CONCAT( id,' - ',COUNT(id), ' matches ', GROUP_CONCAT(elm)) AS "Result"
  FROM t
 WHERE elm IN ( SELECT elm FROM t WHERE id = 3 )
 GROUP BY id 

Demo

于 2020-05-25T22:35:21.847 回答