Mysql高级查询

有表如下;
id cate
1 1,2,3
2 1,5,6
3 2,4,5
4 3,5,6

cate是逗号分隔的字符串

目的查出 cate in (1,3,6)的记录

where('cate','in',[1,3,6])
这样写结果不对
find_in_set 只能查cate包含3的,不是我们想要的结果
select * from A where find_in_set('3', ‘cate’);

解决方案
/******************************/
使用原生查询解决
SELECT * FROM table WHERE CONCAT(",", `cate`, ",") REGEXP ",(1|2|3),"
/*****************************/

posted @ 2023-06-05 15:56  橙子与柠檬  阅读(19)  评论(0)    收藏  举报