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(不少網上提供的解決方案沒有考慮到這種狀況)
相關文章
相關標籤/搜索