FIND_IN_SET()方法

一、基础用法说明

FIND_IN_SET(str, strlist) 函数的作用是:在 strlist(逗号分隔的字符串)中查找 str 的位置,返回值是数字(找到则返回位置,从1开始;没找到返回0)。

结合 MyBatis 的 #{ids} 是为了安全地传入参数,避免 SQL 注入。

二、完整使用示例

1. 场景:根据多个 ID 批量查询数据

假设你有一张 user 表,想通过多个用户 ID(如 1,3,5)查询对应的用户信息,就可以用这个函数。

(1) MyBatis Mapper XML 写法
xml 复制代码
<!-- UserMapper.xml -->
<select id="selectUserByIds" resultType="com.example.entity.User">
    SELECT * FROM user
    WHERE FIND_IN_SET(id, #{ids})
</select>
(2) Mapper 接口定义
java 复制代码
// UserMapper.java
import org.apache.ibatis.annotations.Param;
import java.util.List;
import com.example.entity.User;

public interface UserMapper {
    // 注意:参数名要和 XML 中的 #{ids} 对应,建议用 @Param 显式指定
    List<User> selectUserByIds(@Param("ids") String ids);
}
(3) 业务层调用
java 复制代码
// UserService.java
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.List;
import com.example.entity.User;
import com.example.mapper.UserMapper;

@Service
public class UserService {
    @Resource
    private UserMapper userMapper;

    public List<User> getUserListByIds() {
        // 传入逗号分隔的 ID 字符串
        String ids = "1,3,5";
        // 调用 Mapper 方法
        return userMapper.selectUserByIds(ids);
    }
}
2. 关键注意事项
  • 参数格式#{ids} 接收的必须是逗号分隔的字符串 (如 "1,3,5"),不能是 List 集合直接传入(如果是 List,需要先转成字符串)。
    示例(List 转字符串):

    java 复制代码
    List<Integer> idList = Arrays.asList(1,3,5);
    String ids = String.join(",", idList.stream().map(String::valueOf).toArray(String[]::new));
  • 性能提示FIND_IN_SET() 无法使用索引,数据量大时性能较差,建议优先用 IN (1,3,5)(MyBatis 中可通过 <foreach> 实现)。

  • 返回值逻辑

    • FIND_IN_SET(3, '1,3,5') → 返回 2(第2个位置)
    • FIND_IN_SET(6, '1,3,5') → 返回 0(未找到)

三、对比:FIND_IN_SET vs IN(推荐写法)

如果你的参数是 List 集合,更推荐用 <foreach> 拼接 IN,性能更好:

xml 复制代码
<select id="selectUserByIds" resultType="com.example.entity.User">
    SELECT * FROM user
    WHERE id IN
    <foreach collection="ids" item="id" open="(" separator="," close=")">
        #{id}
    </foreach>
</select>

对应的接口:

java 复制代码
List<User> selectUserByIds(@Param("ids") List<Integer> ids);

总结

  1. FIND_IN_SET(id, #{ids}) 中,#{ids} 必须传入逗号分隔的字符串,函数返回匹配的位置(非0则命中);
  2. 该写法无法使用索引,数据量大时优先用 MyBatis 的 <foreach> 拼接 IN
  3. 使用时注意参数类型:直接传 List 会报错,需转成字符串(或改用 IN 写法)。
相关推荐
逝水如流年轻往返染尘5 分钟前
JAVA中的String类
java
一只叫煤球的猫8 分钟前
ThreadForge 1.2.0 发布:让 Java 并发代码更好写,这次补齐了高阶编排、示例与观测能力
java·设计模式·设计
counting money14 分钟前
Spring框架基础(依赖注入-半注解形式)
java·后端·spring
CN-Dust14 分钟前
【C++】for循环例题专题
java·c++·算法
也许明天y24 分钟前
LangChain4j + Spring Boot 多智能体协调架构原理深度解析
spring boot·后端·agent
染夕陌木27 分钟前
RPC/服务调用框架中“方法无法应用到给定类型”错误的通用排查指南
java·ide·rpc
大大杰哥31 分钟前
String常用方法
java
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index
嵌入式×边缘AI:打怪升级日志1 小时前
嵌入式Linux开发(了解交叉编译工具链的组成)
java·linux·运维
FreeGo~1 小时前
Linux 系统编程 进程篇 (五)
java·linux·服务器