sql 语句中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或记录

猜你喜欢

转载自blog.csdn.net/csdnerM/article/details/118152772
今日推荐