MySql逗號拼接字串查詢的兩種方法
阿新 • • 發佈:2020-01-09
下面兩個函式的使用和FIND_IN_SET
一樣,使用時只需要把FIND_IN_SET
換成FIND_PART_IN_SET
或FIND_ALL_PART_IN_SET
例如某欄位裡是為1,2,3,4,5
使用方法:
第一種,傳入1,6 可以查出來
select * from XXX where FIND_PART_IN_SET('1,6','1,5')
第二種,6 查不出來
select * from XXX where FIND_ALL_PART_IN_SET('1,5')
函式:
第一種:只要包含其中一個就可以被查出來
CREATE DEFINER = `root`@`%` FUNCTION `NewProc`(str1 text,str2 text) RETURNS text BEGIN #傳入兩個逗號分割的字串,判斷第二個字串是否包含第一個字串split之後的單個 DECLARE CURRENTINDEX INT;#當前下標 DECLARE CURRENTSTR text; DECLARE result int; set result = 0; set CURRENTINDEX = 0; set CURRENTSTR = ''; IF str1 IS NOT NULL AND str1 != '' THEN SET CURRENTINDEX = LOCATE(',',str1); WHILE CURRENTINDEX > 0 DO SET CURRENTSTR = substring(str1,1,CURRENTINDEX-1); if FIND_IN_SET(CURRENTSTR,str2) THEN set result = 1; end if; SET str1 = substring(str1,CURRENTINDEX+1); SET CURRENTINDEX = LOCATE(',str1); END WHILE; #只傳一個 和 最後無逗號的情況 IF LENGTH(str1) > 0 THEN if FIND_IN_SET(str1,str2) THEN set result = 1; end if; END IF; END IF; RETURN result; END;
第二種:必須全部包含才可以被查出來
CREATE DEFINER = `root`@`%` FUNCTION `NewProc`(str1 text,str2 text) RETURNS text BEGIN #傳入兩個逗號分割的字串,判斷第二個字串是否全部包含第一個字串split之後的單個 DECLARE CURRENTINDEX INT;#當前下標 DECLARE CURRENTSTR text; DECLARE RESULT int; DECLARE TOTALCOUNT int; DECLARE TRUECOUNT int; set RESULT = 0; set CURRENTINDEX = 0; set CURRENTSTR = ''; set TOTALCOUNT = 0; set TRUECOUNT = 0; IF str1 IS NOT NULL AND str1 != '' THEN SET CURRENTINDEX = LOCATE(',str1); WHILE CURRENTINDEX > 0 DO SET TOTALCOUNT = TOTALCOUNT + 1; SET CURRENTSTR = substring(str1,str2) THEN SET TRUECOUNT = TRUECOUNT + 1; end if; SET str1 = substring(str1,str1); END WHILE; #只傳一個 和 最後無逗號的情況 IF LENGTH(str1) > 0 THEN SET TOTALCOUNT = TOTALCOUNT + 1; if FIND_IN_SET(str1,str2) THEN SET TRUECOUNT = TRUECOUNT + 1; end if; END IF; END IF; IF TOTALCOUNT > 0 AND TRUECOUNT = TOTALCOUNT THEN SET RESULT = 1; END IF; RETURN result; END;
總結
以上所述是小編給大家介紹的MySql逗號拼接字串查詢的兩種方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對我們網站的支援!
如果你覺得本文對你有幫助,歡迎轉載,煩請註明出處,謝謝!