MySQL语句中in的妙用和FIND_IN_SET

383 阅读2分钟

在 SQL 中,INFIND_IN_SET 这两个函数都是用于对数据表进行筛选的常见方法。 IN 函数用于判断一个字段值是否存在某个集合中,而 FIND_IN_SET 函数则用来判断某个值在一个字符串里的位置是否在另一个集合内。本文将会深入介绍和比较这两个函数的使用,以帮助读者更好地运用它们来解决实际问题。

无意中发现了一个in的作用:会根据逗号分割并且查询 在这里插入图片描述这里的characte是一个字符串如上图所示 有什么方法可以查询包含数字为2的数据呢? 于是我们想到了加like: 在这里插入图片描述

这样好像是可以查询出来,但是好像把12也查询出来了 所以我们尝试用in在这里插入图片描述非常好!这个时候已经达到了我们的要求 但是这里需要注意一件事情:如果我们传入的值是字符串,那么就是全匹配查询 如果不加引号传入数字,就是根据,分割查询 在这里插入图片描述 在这里插入图片描述 在这里插入图片描述 博主后来发现了一件事情,这个好像只能查询以2开头的,如果2不在前面就查询不了,具体原因还在研究。。。。

这个时候我们就可以运用mysql中一个自带的函数: FIND_IN_SET(str,strlist) 用法:在这里插入图片描述 MySQL手册中find_in_set函数的语法解释:

FIND_IN_SET(str,strlist)

str 要查询的字符串

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

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

本文详细讲述了 INFIND_IN_SET 这两个函数在 SQL 中的妙用。它们能够非常有效地提高我们查询数据的灵活性和效率,并且能够使我们轻松地处理包含多个条件的复杂筛选条件。当然,在实际使用过程中,我们需要根据具体需求和场景来选择适合的函数,避免滥用导致查询效率下降。希望通过本文的介绍,读者们能够更加深入了解这两个函数的使用方法,并在实际数据库应用中做出更为优秀的决策。