mysql逗号分隔的字符串如何搜索

         通常我们在设计数据库一对多的时候,会采用逗号分隔的字符串的形式来表示,但是查询的时候如何查询呢?

         以下提供两种方式来查询

         原始数据

        

INSERT INTO test(pname,pnum) VALUES('产品1','1,2,4');
INSERT INTO test(pname,pnum) VALUES('产品2','2,4,7');
INSERT INTO test(pname,pnum) VALUES('产品3','3,4');
INSERT INTO test(pname,pnum) VALUES('产品4','1,7,8,9');

INSERT INTO test(pname,pnum) VALUES('产品5','33,4');

      第一种方式

     查找pnum字段中包含3或者9的记录
MySQL> SELECT * FROM test WHERE find_in_set('3',pnum) OR find_in_set('9',pnum);

      第二种方式

      select * from oa_student_archives where CONCAT(',',pe_projects,',') like '%,11,%';

      这两种方式都可以满足要求,大家可以灵活选择。

发布了91 篇原创文章 · 获赞 13 · 访问量 6万+

猜你喜欢

转载自blog.csdn.net/weixin_41751625/article/details/102814812