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),"
/*****************************/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具