当前位置: 首页 > news >正文

简化mybatis @Select IN条件的编写

最近从JPA切换到Mybatis,使用无XML配置,@Select注解直接写到interface上,发现IN条件的编写相当麻烦。

一般得写成这样:

@Select({"<script>","SELECT *", "FROM blog","WHERE id IN", "<foreach item='item' index='index' collection='list'","open='(' separator=',' close=')'>","#{item}","</foreach>","</script>"}) 
List<Blog> selectBlogs(@Param("list") int[] ids);

写的看起来很别扭,原来JPA+Hibernate写HQL就不用额外处理。想着找一下解决方案,一搜确实也有人有同样的痛点。

原来我写的是这样的:

    @Select("select distinct(USER_ID) from SYS_LOGIN_LOG " +"where USER_ID IN (#{userIds}) " +"and TENANT_ID = #{tenantId} " +"and CREATE_TIME between #{startTime} and #{endTime}")List<Long> selectInTimeRange(@Param("userIds") long[] userIds, @Param("tenantId") long tenantId,@Param("startTime") Date startTime, @Param("endTime") Date endTime);

发现解析失败,google了一下,通过增加一个语法处理器就解决了。

在Mapper基类添加这样的处理器

public interface CcBaseMapper<T> extends BaseMapper<T> {/*** 解决mybatis in条件写得难看的问题*/class InConditionDriver extends XMLLanguageDriverimplements LanguageDriver {private final Pattern inPattern = Pattern.compile("\\(#\\{(\\w+)\\}\\)");public SqlSource createSqlSource(Configuration configuration, String script, Class<?> parameterType) {Matcher matcher = inPattern.matcher(script);if (matcher.find()) {script = matcher.replaceAll("(<foreach collection=\"$1\" item=\"__item\" separator=\",\" >#{__item}</foreach>)");}script = "<script>" + script + "</script>";return super.createSqlSource(configuration, script, parameterType);}}

然后添加这个处理器即可:

    @Lang(InConditionDriver.class)@Select("select distinct(USER_ID) from SYS_LOGIN_LOG " +"where USER_ID IN (#{userIds}) " +"and TENANT_ID = #{tenantId} " +"and CREATE_TIME between #{startTime} and #{endTime}")List<Long> selectInTimeRange(@Param("userIds") long[] userIds, @Param("tenantId") long tenantId,@Param("startTime") Date startTime, @Param("endTime") Date endTime);

这样就不报错了。搞掂

http://www.lryc.cn/news/408579.html

相关文章:

  • Windows图形界面(GUI)-MFC-C/C++ - Control
  • SQL Server数据库安全:策略制定与实践指南
  • Spring Boot入门指南:留言板
  • Docker 中安装和配置带用户名和密码保护的 Elasticsearch
  • 面试官:说说JVM内存调优及内存结构
  • Ansible的脚本-----playbook剧本【下】
  • Mysql开启远程控制简化版,亲测有效
  • 【MQTT协议与IoT通信】MQTT协议的使用和管理
  • 根据题意写出完整的css,html和js代码【购物车模块页面及功能实现】
  • AWS免费层之后:了解和管理您的云服务成本
  • Linux定时同步系统时间到硬件时间
  • 网络编程——wireshark抓包、tcp粘包
  • el-table合计行更新问题
  • ChatGPT:数据库不符合第二范式示例
  • 27、美国国家冰雪中心(NSIDC)海冰密集度月数据下载与处理
  • vite环境下使用bootstrap
  • Laravel视图渲染封装
  • C++学习补充2:MySQL select 查询
  • uni-app声生命周期
  • 排序算法--堆排序
  • iPhone 在 App Store 中推出的 PC 模拟器 UTM SE
  • FastAPI删除mongodb重复数据(数据清洗)
  • 移动UI:排行榜单页面如何设计,从这五点入手,附示例。
  • 如何解决 uni-app 项目中 “文件查找失败:‘crypto-js‘“ 的问题
  • Apache DolphinScheduler 3.2.2 版本正式发布!
  • 汇川CodeSysPLC教程03-2-6 ModBus TCP
  • 【Python机器学习】决策树的构造——划分数据集
  • Pip换源使用帮助
  • 力扣1089复写0
  • 10 VUE Element