亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

mysql中find_in_set()函數(shù)的使用及in()用法詳解

2024-07-25 19:08:38
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

MySQL手冊(cè)中find_in_set函數(shù)的語(yǔ)法解釋:

FIND_IN_SET(str,strlist)

str 要查詢的字符串 

strlist 字段名 參數(shù)以”,”分隔 如 (1,2,6,8,10,22) 

查詢字段(strlist)中包含(str)的結(jié)果,返回結(jié)果為null或記錄

假如字符串str在由N個(gè)子鏈組成的字符串列表strlist 中,則返回值的范圍在 1 到 N 之間。 一個(gè)字符串列表就是一個(gè)由一些被 ‘,' 符號(hào)分開的子鏈組成的字符串。如果第一個(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)行。

看不懂概念也沒(méi)事,按下面類子:

例子1:

SELECT FIND_IN_SET('b', 'a,b,c,d');

結(jié)果:2

因?yàn)閎 在strlist集合中放在2的位置 從1開始

select FIND_IN_SET('1', '1'); 返回 就是1 這時(shí)候的strlist集合有點(diǎn)特殊 只有一個(gè)字符串 其實(shí)就是要求前一個(gè)字符串 一定要在后一個(gè)字符串集合中才返回大于0的數(shù)

select FIND_IN_SET('2', '1,2'); 返回2select FIND_IN_SET('6', '1'); 返回0 strlist中不存在str,所以返回0。

find_in_set()和in的區(qū)別:

弄個(gè)測(cè)試表來(lái)說(shuō)明兩者的區(qū)別

CREATE TABLE `tb_test` ( `id` int(8) NOT NULL auto_increment, `name` varchar(255) NOT NULL, `list` varchar(255) NOT NULL, PRIMARY KEY (`id`));INSERT INTO `tb_test` VALUES (1, 'name', 'daodao,xiaohu,xiaoqin');INSERT INTO `tb_test` VALUES (2, 'name2', 'xiaohu,daodao,xiaoqin');INSERT INTO `tb_test` VALUES (3, 'name3', 'xiaoqin,daodao,xiaohu');

原來(lái)以為mysql可以進(jìn)行這樣的查詢:

SELECT id,name,list from tb_test WHERE 'daodao' IN(list); -- (一)

mysql,find_in_set(),函數(shù),in()

實(shí)際上這樣是不行的, 這樣只有當(dāng)list字段的值等于'daodao'時(shí)(和IN前面的字符串完全匹配),查詢才有效,否則都得不到結(jié)果,即使'daodao'真的在list中。

再來(lái)看看這個(gè):

SELECT id,name,list from tb_test WHERE 'daodao' IN ('libk', 'zyfon', 'daodao'); -- (二)

mysql,find_in_set(),函數(shù),in()

這樣是可以的。

這兩條到底有什么區(qū)別呢?為什么第一條不能取得正確的結(jié)果,而第二條卻能取得結(jié)果。原因其實(shí)是(一)中 (list) list是變量, 而(二)中 ('libk', 'zyfon', 'daodao')是常量。

所以如果要讓(一)能正確工作,需要用

find_in_set():SELECT id,name,list from tb_test WHERE FIND_IN_SET('daodao',list); -- (一)的改進(jìn)版

mysql,find_in_set(),函數(shù),in()

總結(jié): 

所以如果list是常量,則可以直接用IN, 否則要用find_in_set()函數(shù)。

也就是這兩個(gè)sql是查詢的效果是相同的:

SELECT * from C_PURCHASINGMASTERDATA where FIND_IN_SET(EKGRP,'C54,C02,C14,C60,C06,C61,C53,C51,C12,C08,C03,C07')SELECT * from C_PURCHASINGMASTERDATA where EKGRP in ('C54','C02','C14','C60','C06','C61','C53','C51','C12','C08','C03','C07')

但是如果第二句sql里面的值是傳入sql的一個(gè)變量字段,那么第二句sql就不好使了。要以實(shí)際情況決定用in還是用 find_in_set()函數(shù) 。

find_in_set()和like的區(qū)別:

主要的區(qū)別就是like是廣泛的模糊查詢,而 find_in_set() 是精確匹配,并且字段值之間用‘,'分開。

現(xiàn)在想查詢擁有角色編號(hào)為2的用戶,用like關(guān)鍵字查詢:

SELECT userid,username,userrole 角色 FROM `user` WHERE userrole LIKE '%2%';

結(jié)果: 

mysql,find_in_set(),函數(shù),in()

用 find_in_set() 查詢:

SELECT userid,username,userrole 角色 FROM `user` WHERE find_in_set('2',userrole)

結(jié)果: 

mysql,find_in_set(),函數(shù),in()

顯然用 find_in_set() 查詢得到的結(jié)果才是我們想要的結(jié)果。所以他倆的

主要的區(qū)別就是like是廣泛的模糊查詢;而 find_in_set() 是精確匹配,并且字段值之間用‘,'分開,F(xiàn)ind_IN_SET查詢的結(jié)果要小于like查詢的結(jié)果。

mysql 中find_in_set()和in()用法比較

在mysql中in可以包括指定的數(shù)字,而find_in_set()用于特定的數(shù)據(jù)類型。

find_in_set 函數(shù)使用方法

個(gè)例子來(lái)說(shuō):

有個(gè)文章表里面有個(gè)type字段,它存儲(chǔ)的是文章類型,有 1頭條、2推薦、3熱點(diǎn)、4圖文...1,12,13 等等 。
現(xiàn)在有篇文章他既是 頭條,又是熱點(diǎn),還是圖文,
type中以 1,3,4 的格式存儲(chǔ)。
那我們?nèi)绾斡胹ql查找所有type中有4圖文標(biāo)準(zhǔn)的文章呢??
這就要我們的 find_in_set 出馬的時(shí)候到了。

以下為引用的內(nèi)容:

select * from article where FIND_IN_SET('4',type)

MySQL手冊(cè)中find_in_set函數(shù)的語(yǔ)法:

FIND_IN_SET(str,strlist)

假如字符串str 在由N 子鏈組成的字符串列表strlist 中,則返回值的范圍在 1 到 N 之間。
一個(gè)字符串列表就是一個(gè)由一些被 ‘,' 符號(hào)分開的子鏈組成的字符串。如果第一個(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)行。

mysql> SELECT FIND_IN_SET('b', 'a,b,c,d');

-> 2 因?yàn)閎 在strlist集合中放在2的位置 從1開始

select FIND_IN_SET('1', '1'); 返回 就是1 這時(shí)候的strlist集合有點(diǎn)特殊 只有一個(gè)字符串 其實(shí)就是要求前一個(gè)字符串 一定要在后一個(gè)字符串集合中 才返回 大于0的數(shù)

select FIND_IN_SET('2', '1,2'); 返回2select FIND_IN_SET('6', '1'); 返回0

注意:

select * from treenodes where FIND_IN_SET(id, '1,2,3,4,5');

使用find_in_set函數(shù)一次返回多條記錄

id 是一個(gè)表的字段,然后每條記錄分別是id等于1,2,3,4,5的時(shí)候
有點(diǎn)類似in (集合)

select * from treenodes where id in (1,2,3,4,5);

弄個(gè)測(cè)試表來(lái)說(shuō)明兩者的區(qū)別

CREATE TABLE `test` (`id` int(8) NOT NULL auto_increment,`name` varchar(255) NOT NULL,`list` varchar(255) NOT NULL,PRIMARY KEY (`id`))INSERT INTO `test` VALUES (1, 'name', 'daodao,www.49028c.com,xiaoqin');INSERT INTO `test` VALUES (2, 'name2', 'xiaohu,daodao,xiaoqin');INSERT INTO `test` VALUES (3, 'name3', 'xiaoqin,daodao,www.49028c.com');

原來(lái)以為MySQL可以進(jìn)行這樣的查詢:

select id, list, name from table where 'daodao' IN (list);

(一)

實(shí)際上這樣是不行的,這樣只有當(dāng)name是list中的第一個(gè)元素時(shí),查詢才有效,否則都得不到結(jié)果,即使'daodao'真的在list中。

再來(lái)看看這個(gè):

select id, list, name from table where 'daodao' IN ('libk', 'zyfon', 'daodao');

(二)

這樣是可以的。
----------------------------------------------------------------
這兩條到底有什么區(qū)別呢?為什么第一條不能取得正確的結(jié)果,而第二條卻能取得結(jié)果。

原因其實(shí)是(一)中 (list) list是變量, 而(二)中 ('libk', 'zyfon', 'daodao')是常量。

所以如果要讓(一)能正確工作,需要用find_in_set():

select id, list, name from table where find_in_set('daodao',list);

(一)的改進(jìn)版。

總結(jié):

所以如果list是常量,則可以直接用IN, 否則要用find_in_set()函數(shù)。

以上所述是小編給大家介紹的mysql中find_in_set()函數(shù)的使用詳解,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MYSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国产精品乱码一区二区三区视频| 精品精品国产高清一毛片一天堂| 93在线视频精品免费观看| 亚洲欧美制服丝袜| 国产麻豆精品在线| 欧美成熟视频| 人人精品人人爱| 日韩性生活视频| 国产成人拍精品视频午夜网站| 国产a亚洲精品| 任你躁av一区二区三区| 男生女生差差差的视频在线观看| 嫩草香蕉在线91一二三区| 欧美午夜电影在线观看| 啦啦啦在线视频免费观看高清中文| 国精产品一区一区三区四川| 日本熟妇成熟毛茸茸| 一本色道久久综合亚洲精品婷婷| 久久综合色一综合色88| 亚洲精品成人a| 国产精品自在线| 日韩专区中文字幕一区二区| av无码久久久久久不卡网站| 欧美一区二区三区性视频| 亚洲爱爱爱爱爱| 日韩欧美一区二区在线视频| 久久成人免费视频| 国产精品亚洲аv天堂网| 婷婷久久综合九色综合绿巨人| 不卡的av一区| 亚洲中国最大av网站| 成人一区二区免费视频| 18啪啪污污免费网站| 99久久99热这里只有精品| 久久婷婷av| jizzzz日本| 欧美三级午夜理伦三级在线观看| 999www人成免费视频| 欧美精品videossex变态| 天天干天天爽| 欧美日韩中文字幕在线观看| 日韩欧美黄色片| 中文字幕精品在线观看| 全色精品综合影院| 日本一区美女| 日本一区二区三区免费视频| 亚洲国产毛片完整版| 亚洲最大成人网4388xx| 337p亚洲精品色噜噜狠狠p| 人人玩人人添人人澡欧美| 日本一二三区在线观看| 久久6免费高清热精品| 亚洲精品午夜av福利久久蜜桃| 欧美激情中文字幕| 亚洲精品人人| 成人精品免费看| 3d动漫精品啪啪一区二区下载| aaa亚洲精品一二三区| 亚洲伦理久久| 青青草手机视频在线观看| 日韩精品无码一区二区| 91麻豆精品91久久久久久清纯| 不卡的av电影| 欧美又粗又大又长| 处破女av一区二区| 欧美成人精品1314www| 婷婷综合久久一区二区三区| 久草视频精品在线| 日韩精品亚洲aⅴ在线影院| 国产精品尤物视频| 欧美裸体一区二区三区| 国产精品久久久久影院老司| 色琪琪丁香婷婷综合久久| 久久精品一偷一偷国产| 最近中文字幕mv第三季歌词| 在线中文字幕一区二区| 亚洲男人第一av| 一级淫片在线观看| 天堂av网在线| 国产精品成人aaaa在线| 国产偷国产偷亚洲高清人白洁| 超碰国产一区| 亚洲国产精品悠悠久久琪琪| 欧洲激情一区二区| 朝桐光av在线一区二区三区| 欧美日韩视频免费播放| 欧美 日韩 激情| 国产精品老熟女视频一区二区| 国产成人精品视频免费| 日本黄色三级视频| 国产伦精品一区二区三区视频小说| 日本成人动漫在线观看| 亚洲精品日本| 国产精品999999| 人妻夜夜添夜夜无码av| www.99热| 欧美国产日本韩| 久久久噜噜噜久久人人看| 别急慢慢来1978如如2| 欧美午夜视频一区二区| 欧美日韩一区二区三区视频播放| 中文字幕高清不卡| 成人综合日日夜夜| 欧美日韩亚洲高清| 亚洲一区中文字幕在线| 欧洲一区二区日韩在线视频观看免费| 51精品视频一区二区三区| 日韩手机在线观看| 亚洲视频二区| 欧美色图另类小说| 黑人欧美xxxx| 国产一区二区日韩精品欧美精品| 天天人人精品| 99久热re在线精品996热视频| 一本一道波多野毛片中文在线| 亚洲欧美日韩一区二区三区在线| 欧美日韩国产在线播放网站| 影音先锋在线一区| 成人一级片网站| 美女又爽又黄免费视频| 国产精品网站一区| 国产在线一区不卡| 欧美性bbwbbwbbwhd| 成人午夜又粗又硬又大| 中文字幕人妻一区二区三区| 国产又粗又猛又黄又爽| 亚洲国产精品影视| 午夜精品久久久久久久99热影院| 人妻av无码专区| 成年人免费视频观看| 日本不卡一区二区三区视频| 天天爽天天爽夜夜爽| 日韩欧美在线中字| eeuss鲁丝片eeuss影院| 日韩av片免费观看| 色噜噜狠狠一区二区三区| 青草成人免费视频| 久久在线精品| 日韩av在线免播放器| 中文字幕午夜精品一区二区三区| 先锋影音男人资源网| 亚洲人成绝费网站色www| 日韩中文字幕综合| 精品女同一区二区三区在线播放| 国产精品久久久久久亚洲调教| 日韩欧美一级视频| 欧美aⅴ在线观看| 九九精品在线观看| 中文字幕在线影视资源| 亚洲天堂影视av| 91精品国产综合久久久久久漫画| 公侵犯人妻一区二区三区| 盗摄女厕thunder| 久久久久国产美女免费网站| 久久综合成人| 日韩人妻精品一区二区三区| 欧美sm极限捆绑bd| 日韩高清不卡在线| 午夜毛片在线观看| 久久小说免费下载| 日本一区二区三区视频| 91精品久久久久久久蜜月| 666欧美在线视频| 三上悠亚av一区二区三区| 欧美亚洲国产一卡| 高清日韩电视剧大全免费| 精品色蜜蜜精品视频在线观看| 日本中文字幕视频一区| 国产99久久久欧美黑人| 黄色软件视频在线观看| 亚洲国产成人在人网站天堂| 久久夜色精品国产噜噜av| 波多野结衣毛片| 亚洲国产精品99| 精品国产精品国产偷麻豆| eeuss性xxxxxx电影| 久久亚洲精品欧美| 国产一区av在线| 最新在线地址| 美女亚洲一区| 女厕盗摄一区二区三区| 亚洲最大的黄色网址| 狠狠色综合久久婷婷| 高清中文字幕在线| 日韩av中文在线| 亚洲а∨天堂久久精品2021| 伊人影院综合网| 免费高清成人| 天天操天天摸天天舔| 九九热视频免费| 中文字幕永久免费| 在线观看完整版免费| 欧美激情女人20p| 一区二区黄色片| 亚洲视频你懂的| 又黄又骚的视频| 久久久久免费看黄a片app| 亚洲资源一区| 久久出品必属精品| 国产成人免费视频| 91免费版黄色| 亚洲精品色图| xxav国产精品美女主播| 国产精品色综合| 欧美精品自拍视频| 香蕉久久久久久久av网站| 国产精品久久777777换脸| 欧美videos极品另类| 全部免费毛片在线播放一个| 波多野结衣电车痴汉| 99九九电视剧免费观看| 国产传媒在线视频| 免费a级片在线观看| yjizz国产| 精品久久久久久久久久久久| 肥婆老bbb肥婆bbbbb| 欧美日本在线视频中文字字幕| 丝袜美腿美女被狂躁在线观看| 国产一区三区在线播放| 欧美α欧美αv大片| 亚洲天天综合| 久久综合88| 日韩精品专区在线影院重磅| av网站大全在线观看| 国产成人av免费看| 亚洲第一福利社区| 国产一区二区电影在线观看| 国产黄色录像视频| 国产精品久久久久久久小唯西川| 日韩 欧美一区二区三区| 最近中文字幕在线中文高清版| 久久福利电影| 欧美日韩精品在线观看| 麻豆精品一二三| 亚洲精品中文字幕有码专区| 国产毛片精品视频| 北京富婆泄欲对白| 四虎成人精品一区二区免费网站| 中文字幕高清20页| 蜜桃av鲁一鲁一鲁一鲁俄罗斯的| 国产又黄又粗又猛又爽的| 亚洲欧美经典视频| 亚洲精品国产精品乱码不99按摩| 中文字幕一区二区三区四区五区六区| 欧美精品videosex极品1| 在线小视频网址| 国产精品久久久久免费a∨| 天天做综合网| 亚洲精品人妻无码| 一区二区在线观看视频| 97在线观看免费视频| 精品人伦一区二区三区蜜桃网站| 国产精品第一页在线| 日韩三级电影网址| 欧美日韩精品在线一区| 蜜臂av日日欢夜夜爽一区| 男人日女人视频网站| 欧美日产国产精品| 可以免费看毛片的网站| 在线精品亚洲欧美日韩国产| 欧美男男青年gay1069videost| 国产在线激情视频| 亚洲精品一区二区三区在线观看| а√在线中文网新版地址在线| 精品网站aaa| 在线观看av不卡| 亚洲一区二区91| 麻豆影视国产在线观看| av网址在线看| 蜜桃视频涩涩| 成人女人a毛片在线看| 999在线观看精品免费不卡网站| 日韩精品人妻中文字幕有码| 性做久久久久久久久久| 99久久精品国产麻豆演员表| 一本色道精品久久一区二区三区| www.好吊色| 欧美妇性猛交视频| 亚洲一二三四2021不卡| 在线播放成人| 色综合久久综合网| 400部精品国偷自产在线观看| 激情成人在线观看| 亚洲自拍偷拍图区| 国产极品美女高潮无套久久久| 国产a精品视频| 色97色成人| 99精品国产一区二区青青牛奶| 久草视频在线免费看| julia一区二区三区中文字幕| 国产一区福利| 成人福利视频网| 久久久成人av毛片免费观看| 成年人网站在线免费观看| 欧美日韩一二三四| 亚洲春色一区二区三区| 黄色网页免费在线观看| 精品入口麻豆88视频| 九色视频网站在线观看| 国产一区二区四区| 91超碰在线免费| 理论片在线不卡免费观看| 久久不卡免费视频| 中文字幕av高清| 91无套直看片红桃在线观看| 综合 欧美 亚洲日本| 免费在线观看黄色小视频| 国产在线精品一区二区三区不卡| avtt中文字幕| 亚洲一区二区成人| 亚洲精品二三区| 成人在线免费观看91| 亚洲一区二区精品在线观看| 中文精品一区二区| 欧美性另类69xxxx| 日韩av在线最新| 国产免费av国片精品草莓男男| 天堂资源在线亚洲视频| 免费久久久久久| 国产欧美日本亚洲精品一4区| 天天摸天天做天天爽水多| 亚洲永久免费视频| 欧美成人精品三级在线观看| 亚洲国产成人无码av在线| 国产一区二区小视频| 性xxxfllreexxx少妇| 久久久亚洲网站| 中文字幕中文字幕在线十八区|