Mysql中find_in_set()函數(shù)用法詳解以及使用場(chǎng)景
一、find_in_set() 函數(shù)詳解
示例:
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
相信大家看完以上示例就知道這個(gè)函數(shù)的大概作用了,以下是MySQL手冊(cè)中官方說(shuō)明
FIND_IN_SET(str,strlist),該函數(shù)的作用是查詢字段(strlist)中是否包含(str)的結(jié)果,
返回結(jié)果為null或記錄 。str 要查詢的字符串
strlist 需查詢的字段,參數(shù)以”,”分隔,例如如 '1,2,3'
假如字符串str在由N個(gè)子鏈組成的字符串列表strlist 中,則返回值的范圍在 1 到 N 之間。 一個(gè)字符串列表
就是一個(gè)由一些被’,‘ 符號(hào)分開(kāi)的子鏈組成的字符串。如果第一個(gè)參數(shù)是一個(gè)常數(shù)字符串,而第二個(gè)是type SET列,
則FIND_IN_SET() 函數(shù)被優(yōu)化,使用比特計(jì)算。
如果str不在strlist 或strlist 為空字符串,則返回值為 0 。
如任意一個(gè)參數(shù)為NULL,則返回值為 NULL。
這個(gè)函數(shù)在第一個(gè)參數(shù)包含一個(gè)逗號(hào)( , )時(shí)將無(wú)法正常運(yùn)行。
概括一下就是(前一個(gè)字符串是A,后一個(gè)字符串是B):
如果B字符串包含A字符串:則返回大于0的值,這個(gè)值就是A字符串在B字符串的所在位置;
如果B字符串不包含A字符串:則返回0;
如果B字符串或者A字符串有任意一個(gè)是null,則返回null;
如果A字符串包含逗號(hào),則無(wú)法執(zhí)行。
二、應(yīng)用場(chǎng)景
就拿若依的權(quán)限認(rèn)證的其中一條sql來(lái)給大家舉例吧:
SELECT dept_id, parent_id, ancestors, order_num, leader, phone FROM sys_dept WHERE dept_id = 101 or FIND_IN_SET(101, ancestors) ;
查詢結(jié)果:
sql想要實(shí)現(xiàn)的功能就是查詢部門id是101的,或者其他部門的ancestors字段(祖先)中有101的所有部門。使用FIND_IN_SET()函數(shù)完全可以實(shí)現(xiàn)。
那有的朋友就會(huì)說(shuō)了,為什么不用in或者like呢,區(qū)別如下:
三、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ì)和字符串的值進(jìn)行完全匹配,所以上面的sql查詢不到記錄。
但是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查詢的結(jié)果要小于like查詢的結(jié)果。
總結(jié)
到此這篇關(guān)于Mysql中find_in_set()函數(shù)用法詳解以及使用場(chǎng)景的文章就介紹到這了,更多相關(guān)Mysql find_in_set()函數(shù)用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySQL的FIND_IN_SET函數(shù)使用方法分享
- Mysql中的find_in_set的使用方法介紹
- Mysql中FIND_IN_SET()和IN區(qū)別簡(jiǎn)析
- mysql通過(guò)find_in_set()函數(shù)實(shí)現(xiàn)where in()順序排序
- MySQL中find_in_set()函數(shù)用法示例詳解
- MySQL之FIND_IN_SET()的用法及說(shuō)明
- mysql查詢FIND_IN_SET?REGEXP實(shí)踐示例
- MySQL中的FIND_IN_SET函數(shù)的使用場(chǎng)景
- mysql中find_in_set()函數(shù)用法及自定義增強(qiáng)函數(shù)詳解
- Mysql中FIND_IN_SET函數(shù)的使用及問(wèn)題
- MySQL FIND_IN_SET函數(shù)的使用場(chǎng)景
相關(guān)文章

銀河麒麟V10安裝MySQL5.7的詳細(xì)過(guò)程

Ubuntu中MySQL的參數(shù)文件my.cnf示例詳析

mysql decimal數(shù)據(jù)類型轉(zhuǎn)換的實(shí)現(xiàn)