mysql中find_in_set()函數(shù)用法及自定義增強(qiáng)函數(shù)詳解
一、find_in_set()
我們知道m(xù)ysql提供了一個(gè)好用的函數(shù)
FIND_IN_SET(str,strlist),
該函數(shù)的作用是查詢(xún)字段(strlist)中是否包含(str)的結(jié)果,
返回結(jié)果為null或記錄 。
str 要查詢(xún)的字符串
strlist 需查詢(xún)的字段,參數(shù)以”,”分隔,例如如 '1,2,3'。
下面有一組示例
select FIND_IN_SET('1', '1,2,3');
// 結(jié)果:1
select FIND_IN_SET('3', '1,2,3');
// 結(jié)果:3
select FIND_IN_SET('4', '1,2,3');
// 結(jié)果:0
// 后一個(gè)包含前一個(gè)返回大于0的元素所在位置,不包含前一個(gè)則返回0我們一般在查詢(xún)的where條件使用 FIND_IN_SET(str,strlist)>0,則說(shuō)明strlist包含str
但是這個(gè)函數(shù)的第一個(gè)參數(shù)只能判斷是單個(gè)字符串,如果我有以下需求
1. 判斷字符串 '1,3' 中的元素是否有任意一個(gè)元素存在字符串 '1,3,4,5,7',意思就是1或者3只要有任意一個(gè)存在字符串 '1,3,4,5,7' 中就算匹配成功。
2. 再比如判斷字符串 '1,3,5' 中的所有元素是否都存在于字符串 '1,3,4,5,7' 中,即1,3,5每個(gè)元素都要在 字符串 '1,3,4,5,7'中能找到才算匹配成功。
針對(duì)需求1,提供了一個(gè)叫 FIND_PART_IN_SET 的函數(shù)
針對(duì)需求2,提供了一個(gè)叫 FIND_ALL_PART_IN_SET 的函數(shù)
二、FIND_PART_IN_SET
CREATE FUNCTION `FIND_PART_IN_SET`(str1 text, str2 text)
RETURNS text
BEGIN
#傳入兩個(gè)逗號(hào)分割的字符串,判斷第二個(gè)字符串是否包含第一個(gè)字符串split之后的單個(gè)
DECLARE CURRENTINDEX INT;#當(dāng)前下標(biāo)
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)>0 THEN
set result = 1;
end if;
SET str1 = substring(str1, CURRENTINDEX + 1);
SET CURRENTINDEX = LOCATE(',', str1);
END WHILE;
#只傳一個(gè) 和 最后無(wú)逗號(hào)的情況
IF LENGTH(str1) > 0 THEN
if FIND_IN_SET(str1, str2)>0 THEN
set result = 1;
end if;
END IF;
END IF;
RETURN result;
END;實(shí)際調(diào)用判斷FIND_PART_IN_SET(str1 ,str2)>0即可,例如FIND_PART_IN_SET('1,3' , '1,3,4,5')>0
三、FIND_ALL_PART_IN_SET
CREATE FUNCTION `FIND_ALL_PART_IN_SET`(str1 text, str2 text)
RETURNS text
BEGIN
#傳入兩個(gè)逗號(hào)分割的字符串,判斷第二個(gè)字符串是否全部包含第一個(gè)字符串split之后的單個(gè)
DECLARE CURRENTINDEX INT;#當(dāng)前下標(biāo)
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, 1, CURRENTINDEX - 1);
if FIND_IN_SET(CURRENTSTR, str2)>0 THEN
SET TRUECOUNT = TRUECOUNT + 1;
end if;
SET str1 = substring(str1, CURRENTINDEX + 1);
SET CURRENTINDEX = LOCATE(',', str1);
END WHILE;
#只傳一個(gè) 和 最后無(wú)逗號(hào)的情況
IF LENGTH(str1) > 0 THEN
SET TOTALCOUNT = TOTALCOUNT + 1;
if FIND_IN_SET(str1, str2)>0 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;實(shí)際調(diào)用判斷FIND_ALL_PART_IN_SET(str1 ,str2)>0即可,例如FIND_PART_IN_SET('1,3,5' , '1,3,4,5,7')>0
附FIND_IN_SET()和IN、LIKE的區(qū)別:
1.IN和FIND_IN_SET的區(qū)別:
SELECT dept_id, parent_id, ancestors, order_num, leader, phone FROM sys_dept
WHERE '101' IN ('101,102') ;

in后面只能跟常量, 如果跟字符串的話(huà),就會(huì)和字符串的值進(jìn)行完全匹配,所以上面的sql查詢(xún)不到記錄。
但是find_in_set()函數(shù)可以使用常量或字段。
2.like和FIND_IN_SET的區(qū)別:
SELECT dept_id, parent_id, ancestors, order_num, leader, phone FROM sys_dept WHERE ancestors LIKE '%10%' ;

SELECT dept_id, parent_id, ancestors, order_num, leader, phone FROM sys_dept WHERE FIND_IN_SET(10, ancestors) ;

like是廣泛的模糊匹配,字符串中沒(méi)有分隔符,F(xiàn)ind_IN_SET 是精確匹配,字段值會(huì)以英文”,”分隔,
Find_IN_SET查詢(xún)的結(jié)果要小于like查詢(xún)的結(jié)果。
總結(jié)
到此這篇關(guān)于mysql中find_in_set()函數(shù)用法及自定義增強(qiáng)函數(shù)詳解的文章就介紹到這了,更多相關(guān)mysql find_in_set()函數(shù)用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- mysql中find_in_set()函數(shù)的使用及in()用法詳解
- Mysql中find_in_set()函數(shù)用法詳解以及使用場(chǎng)景
- mysql中find_in_set()函數(shù)的使用詳解
- mysql通過(guò)find_in_set()函數(shù)實(shí)現(xiàn)where in()順序排序
- MySQL中find_in_set()函數(shù)用法示例詳解
- mysql中find_in_set()函數(shù)用法及自定義增強(qiáng)函數(shù)
- MySQL中FIND_IN_SET()函數(shù)與in的區(qū)別及說(shuō)明
- MySQL FIND_IN_SET字符串函數(shù)深度解析
相關(guān)文章
如何保護(hù)MySQL中重要數(shù)據(jù)的方法
在日常的工作中,保護(hù)數(shù)據(jù)免受未授權(quán)用戶(hù)的侵犯是系統(tǒng)管理員特別關(guān)心的問(wèn)題。如果你目前用的是MySQL,就可以使用一些方便的功能來(lái)保護(hù)系統(tǒng),來(lái)大大減少機(jī)密數(shù)據(jù)被未授權(quán)用戶(hù)訪(fǎng)問(wèn)的風(fēng)險(xiǎn)2011-10-10
MYSQL復(fù)雜查詢(xún)練習(xí)題以及答案大全(難度適中)
在我們學(xué)習(xí)mysql數(shù)據(jù)庫(kù)時(shí)需要一些題目進(jìn)行練習(xí),下面這篇文章主要給大家介紹了關(guān)于MYSQL復(fù)雜查詢(xún)練習(xí)題以及答案的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),這些練習(xí)題難度適中,需要的朋友可以參考下2022-08-08
MySQL存儲(chǔ)過(guò)程的傳參和流程控制示例講解
這篇文章主要介紹了MySQL存儲(chǔ)過(guò)程的傳參和流程控制示例講解,?repeat和Loop區(qū)別是repeat有自己退出循環(huán)的語(yǔ)句until,Loop使用的是if判斷語(yǔ)句,本文結(jié)合示例代碼詳細(xì)講解,需要的朋友可以參考下2023-02-02
MySql兩表關(guān)聯(lián)更新update示例SQL語(yǔ)句(用一個(gè)表更新另一個(gè)表)
這篇文章主要介紹了MySql兩表關(guān)聯(lián)更新update示例SQL語(yǔ)句的相關(guān)資料,文中分享了兩種處理方式(保留/清空未匹配數(shù)據(jù)),演示觸發(fā)器記錄更新操作至audit表,并通過(guò)示例SQL展示不同場(chǎng)景下更新效果及注意事項(xiàng),需要的朋友可以參考下2025-06-06

