news 2026/3/8 2:49:53

FIND_IN_SET()方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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 写法
<!-- UserMapper.xml --><selectid="selectUserByIds"resultType="com.example.entity.User">SELECT * FROM user WHERE FIND_IN_SET(id, #{ids})</select>
(2) Mapper 接口定义
// UserMapper.javaimportorg.apache.ibatis.annotations.Param;importjava.util.List;importcom.example.entity.User;publicinterfaceUserMapper{// 注意:参数名要和 XML 中的 #{ids} 对应,建议用 @Param 显式指定List<User>selectUserByIds(@Param("ids")Stringids);}
(3) 业务层调用
// UserService.javaimportorg.springframework.stereotype.Service;importjavax.annotation.Resource;importjava.util.List;importcom.example.entity.User;importcom.example.mapper.UserMapper;@ServicepublicclassUserService{@ResourceprivateUserMapperuserMapper;publicList<User>getUserListByIds(){// 传入逗号分隔的 ID 字符串Stringids="1,3,5";// 调用 Mapper 方法returnuserMapper.selectUserByIds(ids);}}
2. 关键注意事项
  • 参数格式#{ids}接收的必须是逗号分隔的字符串(如"1,3,5"),不能是 List 集合直接传入(如果是 List,需要先转成字符串)。
    示例(List 转字符串):
    List<Integer>idList=Arrays.asList(1,3,5);Stringids=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,性能更好:

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

对应的接口:

List<User>selectUserByIds(@Param("ids")List<Integer>ids);

总结

  1. FIND_IN_SET(id, #{ids})中,#{ids}必须传入逗号分隔的字符串,函数返回匹配的位置(非0则命中);
  2. 该写法无法使用索引,数据量大时优先用 MyBatis 的<foreach>拼接IN
  3. 使用时注意参数类型:直接传 List 会报错,需转成字符串(或改用IN写法)。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/2 22:16:08

大语言模型的推理能力:未来发展方向

大语言模型的推理能力:未来发展方向 关键词:大语言模型、推理能力、未来发展、自然语言处理、人工智能 摘要:本文围绕大语言模型的推理能力展开深入探讨。首先介绍了大语言模型推理能力相关背景,包括目的范围、预期读者等。接着阐述了核心概念与联系,详细讲解了核心算法原理…

作者头像 李华
网站建设 2026/3/6 22:51:59

导师严选9个AI论文网站,专科生搞定毕业论文+格式规范!

导师严选9个AI论文网站&#xff0c;专科生搞定毕业论文格式规范&#xff01; AI 工具助力论文写作&#xff0c;专科生也能轻松应对 对于很多专科生来说&#xff0c;撰写毕业论文不仅是一项学术任务&#xff0c;更是一次心理和时间上的双重挑战。尤其是在面对格式规范、内容逻…

作者头像 李华
网站建设 2026/3/4 12:57:51

零基础玩转Qwen3-Embedding:4B模型保姆级部署教程

零基础玩转Qwen3-Embedding&#xff1a;4B模型保姆级部署教程 1. 为什么你需要关注 Qwen3-Embedding-4B&#xff1f; 你有没有遇到过这些问题&#xff1a; 想搭建一个智能搜索系统&#xff0c;但传统关键词匹配效果差&#xff1f;做推荐系统时&#xff0c;发现用户行为数据不…

作者头像 李华
网站建设 2026/3/8 0:00:50

springboot_ssm839学校招生系统ssm

目录具体实现截图学校招生系统SSM框架摘要核心功能模块技术实现特点扩展性与安全性系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;具体实现截图 学校招生系统SSM框架摘要 基于SpringBoot和SSM&#xff08;Sp…

作者头像 李华
网站建设 2026/3/3 22:05:52

springboot_ssm841智慧餐厅点餐管理系统ssm三个角色 员工

目录 具体实现截图员工角色功能摘要 系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 具体实现截图 员工角色功能摘要 在SpringBootSSM框架开发的智慧餐厅点餐管理系统中&#xff0c;员工角色是系统的核心操作…

作者头像 李华