使用sql计算json中的匹配数?

368yc8dk  于 2021-07-26  发布在  Java
关注(0)|答案(1)|浏览(290)

下面是一个示例表:

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

我想从第3行得到匹配数的和 json_txt 在另一排。
以下是每行的计数结果:

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]', '$')

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

2w3rbyxf

2w3rbyxf1#

首先, 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

演示

相关问题