查找MySQL JSON对象或数组的交集

时间:2017-06-21 23:43:18

标签: mysql json mariadb

问题是关于MySQL/MariaDB JSON Functions 如何找到多个JSON结构的交集? 在PHP中,使用以下代码完成:

array_intersect(
    ['a', 'b'],
    ['b', 'c']
);

如果我们想象一个名为JSON_INTERSECT的函数,代码将如下所示:

SET @json1 = '{"key1": "a", "key2": "b"}';
SET @json2 = '["b", "c"]';
SET @json3 = '["c", "d"]';

SELECT JSON_INTERSECT(@json1, @json2); // returns '["b"]';
SELECT JSON_INTERSECT(@json1, @json3); // returns NULL;

1 个答案:

答案 0 :(得分:0)

看起来没有好的内置方法可以做到这一点,在这个主题上仍然没有好的答案,所以我想我会加入我的快速&肮脏的解决如果执行下面的代码,它将创建一个名为MY_JSON_INTERSECT的函数,该函数将完全按照指定的原始海报输出结果。确保你看过这个并且在信任我的代码之前创建一个新函数是正确的:

delimiter $$
CREATE FUNCTION `MY_JSON_INTERSECT`(Array1 VARCHAR(1024), Array2 VARCHAR(1024)) RETURNS varchar(1024)
BEGIN
    DECLARE x int;
    DECLARE val, output varchar(1024);
    SET output = '[]';
    SET x = 0;
    IF JSON_LENGTH(Array2) < JSON_LENGTH(Array1) THEN
        SET val = Array2;
        SET Array2 = Array1;
        SET Array1 = val;
    END IF;
    WHILE x < JSON_LENGTH(Array1) DO
        SET val = JSON_EXTRACT(Array1, CONCAT('$[',x,']'));
        IF JSON_CONTAINS(Array2,val) THEN
            SET output = JSON_MERGE(output,val);
        END IF;
        SET x = x + 1; 
    END WHILE;
    IF JSON_LENGTH(output) = 0 THEN
        RETURN NULL;
    ELSE
        RETURN output;
    END IF;
END$$

然后您可以像这样调用函数:

SELECT MY_JSON_INTERSECT('[1,2,3,4,5,6,7,8]','[0,3,5,7,9]');

输出:

[3,5,7]

这不是很漂亮或有效,但是它有效...希望很快会有更好的答案。