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

  保存成函數之后,執行測試案例:

select INTE_ARRAY("8,9","8,22,33,7") as is_inte_array;
-- 返回1
select INTE_ARRAY("1,9","8,22,33,7") as is_inte_array;
-- 返回0
select INTE_ARRAY(",","8,22,33,7") as is_inte_array;
-- 返回0(很多網上提供的解決方案沒有考慮到這種情況)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM