MySql精确匹配“,“分隔开的内容的函数语法
最近有一个需求,主表和从表关系是一对多的,但是查询的时候要把从表的字段作为查询条件,且要把匹配到的所有数据进行填充
因此就出现问题了,例如:我传入type=5 如果用 like 去匹配,就会匹配出25,55,255的数据,但是这些都不是要返回的
前提:已经将从表拼接在一起了
SELECT order_no,
GROUP_CONCAT(DISTINCT type_id) AS typeId,
GROUP_CONCAT(DISTINCT type_name) AS typeName
FROM A
GROUP BY order_no)
解决:
AND FIND_IN_SET(#{dto.type}, type_id) > 0
函数解释:
FIND_IN_SET是 MySQL 提供的一个函数,用于在逗号分隔的字符串中查找某个值是否存在。它返回找到的值在字符串中的位置(从 1 开始),如果找不到,则返回 0
完美解决 end。