当前位置: 首页 > 编程笔记 >

mysql中find_in_set函数的基本使用方法

狄飞尘
2023-03-14
本文向大家介绍mysql中find_in_set函数的基本使用方法,包括了mysql中find_in_set函数的基本使用方法的使用技巧和注意事项,需要的朋友参考一下

前言

这是我最近新接触到的一个函数,

我在项目中的使用场景是这样的:

有一个应用类型表,表中有parentId字段和parentIds字段,前者为父级id,后者为多级父级id,在库中都是varchar类型,parentIds由多个父级id拼接而成由","分隔.

组长告知我可以使用该函数,就去进行了了解与使用.

语法

FIND_IN_SET(str,strlist)

定义

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

strlist:一个由英文逗号“,”链接的字符串,例如:"a,b,c,d",该字符串形式上类似于SET类型的值被逗号给链接起来。

示例:SELECT FIND_IN_SET('b','a,b,c,d'); //返回值为2,即第2个值

例子

有个文章表里面有个type字段,它存储的是文章类型,有 1头条、2推荐、3热点、4图文等等 。
现在有篇文章他既是头条,又是热点,还是图文,type中以 1,3,4 的格式存储。那我们如何用sql查找所有type中有4的图文类型的文章呢?

这就可以使用 find_in_set 了。以下为引用的内容:

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

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); -- (一)

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

再来看看这个:

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

这样是可以的。

这两条到底有什么区别呢?为什么第一条不能取得正确的结果,而第二条却能取得结果。原因其实是(一)中 (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函数的基本使用方法的文章就介绍到这了,更多相关mysql find_in_set函数使用内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!

 类似资料:
  • 1.1 函数的定义 Python 使用 def 保留字定义一个函数,语法形式如下: def <函数名>(<参数列表>): <函数体> return <返回值列表> 函数调用的形式如下: <函数名>(<参数列表>) 1.2 函数的参数传递 普通参数 def 函数名(普通参数): 默认值参数 默认值参数必须在普通参数后面。

  • 问题内容: 我该怎么做: 问题答案: 如果找到匹配项,则返回匹配的索引;如果找不到,则返回0。由于0为FALSE,因此您可以使用

  • 本文向大家介绍Python字符编码与函数的基本使用方法,包括了Python字符编码与函数的基本使用方法的使用技巧和注意事项,需要的朋友参考一下 一、Python2中的字符存在的解码编码问题 如果是现在正在用Python2的人应该都知道存在字符编码问题,就举一个最简单的例子吧:Python2是无法在命令行直接打印中文的,当然他也是不会报错的,顶多是一堆你看不懂的乱码。如果想在直接显示中文,我们是可以

  • 本文向大家介绍JavaScript函数使用的基本教程,包括了JavaScript函数使用的基本教程的使用技巧和注意事项,需要的朋友参考一下  函数是一组可重用的代码,可以在程序的任何地方被调用。这消除了一次又一次地写入相同的代码的需要。这将帮助程序员编写模块化代码。您可以在一些小且易于管理的功能划分大程序。 像任何其他高级编程语言,JavaScript支持所有必要写模块化的代码使用函数的特点。 一

  • 本文向大家介绍MySQL中关于临时表的一些基本使用方法,包括了MySQL中关于临时表的一些基本使用方法的使用技巧和注意事项,需要的朋友参考一下 临时表可能是非常有用的,在某些情况下,保持临时数据。最重要的是应该知道的临时表是,他们将当前的客户端会话终止时被删除。 临时表中添加MySQL版本3.23。如果您使用的是旧版本的MySQL比3.23,可以不使用临时表,但可以使用堆表。 如前所述临时表将只持

  • 本文向大家介绍es6中reduce的基本使用方法,包括了es6中reduce的基本使用方法的使用技巧和注意事项,需要的朋友参考一下 前言 为啥要把es6 中 reduce 单独拿出来说呢,因为这个功能实在太骚,值得如此。 reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。reduce() 方法接受四个参数:初始值(或者上一次回调函数的返回值),当前