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