怎么在mysql中使用find

57次阅读
没有评论

共计 4087 个字符,预计需要花费 11 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章将为大家详细讲解有关怎么在 mysql 中使用 find_in_set()函数,文章内容质量较高,因此丸趣 TV 小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

MySQL 手册中 find_in_set 函数的语法解释:

FIND_IN_SET(str,strlist)

str 要查询的字符串

strlist 字段名 参数以”,”分隔 如 (1,2,6,8,10,22)

查询字段 (strlist) 中包含 (str) 的结果,返回结果为 null 或记录

假如字符串 str 在由 N 个子链组成的字符串列表 strlist 中,则返回值的范围在 1 到 N 之间。一个字符串列表就是一个由一些被‘, 符号分开的子链组成的字符串。如果第一个参数是一个常数字符串,而第二个是 type SET 列,则 FIND_IN_SET() 函数被优化,使用比特计算。如果 str 不在 strlist 或 strlist 为空字符串,则返回值为 0。如任意一个参数为 NULL,则返回值为 NULL。这个函数在第一个参数包含一个逗号 (‘,) 时将无法正常运行。

看不懂概念也没事,按下面类子:

例子 1:

SELECT FIND_IN_SET(b ,  a,b,c,d

结果:2

因为 b 在 strlist 集合中放在 2 的位置 从 1 开始

select FIND_IN_SET(1 , 1 返回 就是 1 这时候的 strlist 集合有点特殊 只有一个字符串 其实就是要求前一个字符串 一定要在后一个字符串集合中才返回大于 0 的数

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

find_in_set()和 in 的区别:

弄个测试表来说明两者的区别

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

原来以为 mysql 可以进行这样的查询:

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

怎么在 mysql 中使用 find_in_set()函数 

实际上这样是不行的,这样只有当 list 字段的值等于 daodao 时(和 IN 前面的字符串完全匹配),查询才有效,否则都得不到结果,即使 daodao 真的在 list 中。

再来看看这个:

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

怎么在 mysql 中使用 find_in_set()函数 

这样是可以的。

这两条到底有什么区别呢?为什么第一条不能取得正确的结果,而第二条却能取得结果。原因其实是(一)中 (list) list 是变量,而(二)中 (libk , zyfon , daodao)是常量。

所以如果要让(一)能正确工作,需要用

find_in_set():
SELECT id,name,list from tb_test WHERE FIND_IN_SET(daodao ,list); -- (一)的改进版

怎么在 mysql 中使用 find_in_set()函数 

总结:

所以如果 list 是常量,则可以直接用 IN,否则要用 find_in_set()函数。

也就是这两个 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 的一个变量字段,那么第二句 sql 就不好使了。要以实际情况决定用 in 还是用 find_in_set()函数。

find_in_set()和 like 的区别:

主要的区别就是 like 是广泛的模糊查询,而 find_in_set() 是精确匹配,并且字段值之间用‘, 分开。

现在想查询拥有角色编号为 2 的用户,用 like 关键字查询:

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

结果:

怎么在 mysql 中使用 find_in_set()函数 

用 find_in_set() 查询:

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

结果:

怎么在 mysql 中使用 find_in_set()函数 

显然用 find_in_set() 查询得到的结果才是我们想要的结果。所以他俩的

主要的区别就是 like 是广泛的模糊查询;而 find_in_set() 是精确匹配,并且字段值之间用‘, 分开,Find_IN_SET 查询的结果要小于 like 查询的结果。

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

在 mysql 中 in 可以包括指定的数字,而 find_in_set()用于特定的数据类型。

find_in_set 函数使用方法

个例子来说:

有个文章表里面有个 type 字段,它存储的是文章类型,有 1 头条、2 推荐、3 热点、4 图文 …1,12,13 等等。
现在有篇文章他既是 头条,又是热点,还是图文,
type 中以 1,3,4 的格式存储。
那我们如何用 sql 查找所有 type 中有 4 图文标准的文章呢??
这就要我们的 find_in_set 出马的时候到了。

以下为引用的内容:

select * from article where FIND_IN_SET(4 ,type)

MySQL 手册中 find_in_set 函数的语法:

FIND_IN_SET(str,strlist)

假如字符串 str 在由 N 子链组成的字符串列表 strlist 中,则返回值的范围在 1 到 N 之间。
一个字符串列表就是一个由一些被‘, 符号分开的子链组成的字符串。如果第一个参数是一个常数字符串,而第二个是 type SET 列,则 FIND_IN_SET() 函数被优化,使用比特计算。

如果 str 不在 strlist 或 strlist 为空字符串,则返回值为 0。如任意一个参数为 NULL,则返回值为 NULL。这个函数在第一个参数包含一个逗号 (‘,) 时将无法正常运行。

mysql  SELECT FIND_IN_SET(b ,  a,b,c,d

– 2 因为 b 在 strlist 集合中放在 2 的位置 从 1 开始

select FIND_IN_SET(1 , 1 返回 就是 1 这时候的 strlist 集合有点特殊 只有一个字符串 其实就是要求前一个字符串 一定要在后一个字符串集合中 才返回 大于 0 的数

select FIND_IN_SET( 2 ,  1,2   返回 2
select FIND_IN_SET(6 ,  1   返回 0 

注意:

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

使用 find_in_set 函数一次返回多条记录

id 是一个表的字段,然后每条记录分别是 id 等于 1,2,3,4,5 的时候
有点类似 in(集合)

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

弄个测试表来说明两者的区别

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.jb51.net,xiaoqin 
INSERT INTO `test` VALUES (2,  name2 ,  xiaohu,daodao,xiaoqin 
INSERT INTO `test` VALUES (3,  name3 ,  xiaoqin,daodao,www.jb51.net

原来以为 MySQL 可以进行这样的查询:

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

(一)

实际上这样是不行的,这样只有当 name 是 list 中的第一个元素时,查询才有效,否则都得不到结果,即使 daodao 真的在 list 中。

再来看看这个:

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

(二)

这样是可以的。
—————————————————————-
这两条到底有什么区别呢?为什么第一条不能取得正确的结果,而第二条却能取得结果。

原因其实是(一)中 (list) list 是变量,而(二)中 (libk , zyfon , daodao)是常量。

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

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

关于怎么在 mysql 中使用 find_in_set()函数就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计4087字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)