iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >怎么在mysql中使用find_in_set()函数
  • 654
分享到

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

2024-04-02 19:04:59 654人浏览 泡泡鱼
摘要

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

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

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()函数就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: 怎么在mysql中使用find_in_set()函数

本文链接: https://www.lsjlt.com/news/55349.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • find_in_set()函数怎么在mysql中使用
    这期内容当中小编将会给大家带来有关find_in_set()函数怎么在mysql中使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。MySQL手册中find_in_set...
    99+
    2024-04-02
  • 怎么在mysql中使用find_in_set()函数
    这篇文章将为大家详细讲解有关怎么在mysql中使用find_in_set()函数,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。MySQL手册中find_in...
    99+
    2024-04-02
  • Mysql中find_in_set()函数怎么使用
    这篇“Mysql中find_in_set()函数怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起...
    99+
    2023-03-13
    mysql find_in_set()
  • mysql中find_in_set函数使用无效怎么解决
    如果在MySQL中使用find_in_set函数时出现无效的问题,可能是因为函数的参数不正确或者数据存储格式有问题。以下是一些解决方...
    99+
    2024-04-09
    mysql
  • MySQL中find_in_set()函数用法详解
    1、 find_in_set()官方涵义(MySQL手册中语法说明) FIND_IN_SET(str,strlist),该函数的作用是查询字段(strlist) 中是否包含(str)的结果,返回结果为...
    99+
    2023-10-02
    mysql 数据库 sql
  • mysql中find_in_set函数的用法是什么
    在 MySQL 中,FIND_IN_SET 函数用于在一个逗号分隔的字符串列表中查找某个值,并返回其在列表中的索引位置。该函数的语法...
    99+
    2024-04-09
    mysql
  • mysql中find_in_set函数的作用是什么
    在 MySQL 中,FIND_IN_SET() 函数用于在一个逗号分隔的字符串列表中查找一个指定的值,并返回其在列表中的位置(从1开...
    99+
    2024-04-09
    mysql
  • Mysql中的find_in_set() 函数用法详解及使用场景
    一、find_in_set() 函数详解 示例: select FIND_IN_SET('1', '1,2,3');// 结果:1select FIND_IN_SET('3', '1,2,3');// 结果:3select FIN...
    99+
    2023-08-20
    mysql 数据库 java
  • MySQL中find_in_set()函数用法示例详解
    目录1、 find_in_set()官方涵义(MySQL手册中语法说明)2、find_in_set() 和 in 的区别3、应用场景3.1 文章表type字段查询3.2 部门树查询,...
    99+
    2024-04-02
  • Mysql中find_in_set()函数用法详解以及使用场景
    目录一、find_in_set() 函数详解二、应用场景三、FIND_IN_SET()和IN、LIKE的区别:1.IN和FIND_IN_SET的区别:2.like和FIND_IN_SET的区别:总结一、find_in_s...
    99+
    2023-03-10
    mysql find_in_set()函数 mysql find_in_set() mysql的like查询
  • mysql中的find_in_set字符串查找函数如何使用
    本篇内容介绍了“mysql中的find_in_set字符串查找函数如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,...
    99+
    2024-04-02
  • 怎么在mysql中使用if函数
    今天就跟大家聊聊有关怎么在mysql中使用if函数,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。具体场景如下, 先看看表结构:CREATE...
    99+
    2024-04-02
  • MySQL INSTR() 和 FIND_IN_SET() 函数有什么区别
    MySQL INSTR() 函数用于在字符串中查找子字符串,并返回子字符串在原字符串中的位置。它的语法如下:INSTR(str, s...
    99+
    2023-10-20
    MySQL
  • sql中find_in_set函数的作用是什么
    find_in_set 函数用于在一个逗号分隔的字符串列表中查找指定的值。它接受两个参数,第一个参数是要查找的值,第二个参数是包含值...
    99+
    2024-04-09
    sql
  • sql中find_in_set函数的用法是什么
    在SQL中,FIND_IN_SET()函数用于在一个逗号分隔的字符串列表中查找某个值,并返回其位置。该函数的语法如下: FIND_I...
    99+
    2024-04-09
    sql
  • MySQL INSTR() 和 FIND_IN_SET() 函数有什么区别?
    众所周知,这两个函数都用于根据它们提供的参数搜索字符串,但它们之间存在一些显着差异,如下所示FIND_IN_SET()函数使用的字符串列表本身就是一个包含以逗号分隔的子字符串的字符串。而 INSTR() 函数包含一个字符串,它将从中查找子字...
    99+
    2023-10-22
  • replace函数在mysql怎么使用
    replace函数作用:mysql中replace函数的作用是对数据表中字段的字符进行替换。replace函数语法:update `table_name` SET `field_name` = replace (`field_name`,&...
    99+
    2024-04-02
  • 在MYSQL中使用EXISTS函数
    MYSQL中EXISTS的用法,附带代码示例 在MYSQL数据库中,EXISTS是一个非常有用的操作符,用于判断一个子查询是否至少返回了一行数据。它通常与WHERE子句一起使用...
    99+
    2024-02-24
    mysql 用法 exists
  • oracle find_in_set函数的作用是什么
    Oracle中并没有内置的find_in_set函数,该函数通常用于在MySQL中,用来判断一个值是否在一个逗号分隔的字符串中。 在...
    99+
    2024-04-09
    oracle
  • oracle find_in_set函数的用法是什么
    FIND_IN_SET 函数用于在逗号分隔的字符串列表中查找指定的值,并返回其在列表中的位置。其语法如下: FIND_IN_SET(...
    99+
    2024-04-09
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作