MYSQL交集函数

BEGIN

    DECLARE idx INT DEFAULT 0 ; -- B 集合单元索引

    DECLARE len INT DEFAULT 0;-- B 集合表达式长度

    DECLARE llen INT DEFAULT 0;-- 最后检查位置

    DECLARE clen INT DEFAULT 0;-- 当前检查位置

    DECLARE tmpStr varchar(255);-- 临时检查数据集

    DECLARE curt varchar(255);-- B 当前检查的单元

    SET len = LENGTH(setB);

    WHILE idx < len DO

        SET idx = idx + 1;

        SET tmpStr = SUBSTRING_INDEX(setB,",",idx);

        SET clen = LENGTH(tmpStr);

-- 获取当前 setB 中的单元

        IF idx = 1 THEN SET curt = tmpStr;

        ELSE SET curt = SUBSTRING(setB,llen+2,clen-llen-1);

        END IF;

-- 检查是否存在于 setA 中

        IF curt != '' and FIND_IN_SET(curt,setA) > 0 THEN RETURN 1;

        END IF;

-- 当前检查终点与上次检查终点相同则跳出

        IF clen <= llen THEN RETURN 0;

        END IF;

        SET llen = clen;

    END WHILE;

    RETURN 0;

END

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容