通常我们在设计数据库一对多的时候,会采用逗号分隔的字符串的形式来表示,但是查询的时候如何查询呢?
以下提供两种方式来查询
原始数据
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,%';
这两种方式都可以满足要求,大家可以灵活选择。