mysql中当查询条件数据是以“,“逗号形式分割的时候怎么去查(FIND_IN_SET)

一般当查询的字段中保存的是“1,2,3,4”形式的数据,当你去匹配其中的1,第一时间想到的可能是使用like去进行匹配。
但如果这样去查的话虽然能后实现但并不够严谨。like又称为模糊查询,看到模糊两个字应该就会明白了,它查出来的数据可能不是精确的。
举个例子:

teacher_idbj_idname
11,2,3 ,5张老师
222,4,5陈老师

附上sql

CREATE TABLE tb_test (
id int(8) NOT NULL auto_increment,
bj_id varchar(255),
name varchar(255),
PRIMARY KEY (id)
);
INSERT INTO tb_test VALUES (1, ‘1,2,3,5’, ‘张老师’);
INSERT INTO tb_test VALUES (2, ‘22,4,5’, ‘陈老师’);

如上表保存了张老师和陈老师的部分信息,class字段对应的是两个老师所教班级
如果查班级id为2的有几个老师在教,如果使用like去查:

SELECT * FROM tb_test WHERE bj_id LIKE "%2%"

所得结果:
在这里插入图片描述
这个结果可以看到明显不对。按理说想要的数据是张老师这条数据而不是把陈老师也查出来。这里把陈老师也查出来的原因很简单,因为陈老师所教班级id中有个id为22,使用like“%2%”进行匹配时也包含了2。所以陈老师也被查出来了。

所以这里我们要用到FIND_IN_SET这个函数
FIND_IN_SET(需匹配的数据,以逗号分割的数据)

在这里插入代码片

SELECT * FROM tb_test WHERE  FIND_IN_SET('2',bj_id )

在这里插入图片描述
但FIND_IN_SET存在一定的限制条件,它只能筛选以,号分割的数据其他特殊符号则无法筛选。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值