iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式
  • 748
分享到

如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式

2023-06-21 22:06:31 748人浏览 安东尼
摘要

这篇文章给大家分享的是有关如何使用mybatis注解方式完成输入参数为list的sql语句拼接方式的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Mybatis注解完成输入参数为list的SQL语句拼接首先将lis

这篇文章给大家分享的是有关如何使用mybatis注解方式完成输入参数为list的sql语句拼接方式的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

Mybatis注解完成输入参数为list的SQL语句拼接

首先将list集合拼接成一个"1,2,3,4"格式的字符串

然后将这个字符串封装到一个类中:TyreInfoIdStr

如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式

这里的@SelectProvider是调用一个外部的类的方法的返回值作为sql语句。

如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式

在这个方法中拼接SQL语句与list集合的字符串,我这里是提前拼接过了。

如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式

拼接查询条件为list集合的sql函数

当deptId 为1时 sql语句不做更改

当deptId 为其他数字时 list中的id项作为sql查询条件

刚开始编写的时候思路是用or语句进行循环遍历 重复加上or的sql语句来查询

发现比较复杂 最后采取了sql的in函数来实现

public String getDeptIdSql(List<Long> deptIdList){    Iterator<Long> it = deptIdList.iterator();    //当部门id为1时  不采用筛选    while(it.hasNext()){          Long deptId = it.next();          if(deptId == 1){                return "";          }    }          //拼接in条件语句          String s = "";          for(int i = 0; i < deptIdList.size();i++){                if(i!=(deptIdList.size()-1)){                      s += deptIdList.get(i) + ",";                }else{                      s += deptIdList.get(i);                }          }          String sql = " and mtMaintenanceStandard.dept_Id in (" + s + ") ";          return sql;}

编写完成后发现函数有可以提高函数的复用性,将mtMaintenanceStandard.dept_Id设为传入的变量

最后得到

public String getDeptIdSql(String condition,List<Long> deptIdList){    Iterator<Long> it = deptIdList.iterator();    //当部门id为1时  不采用筛选    while(it.hasNext()){          Long deptId = it.next();          if(deptId == 1){                return "";          }    }          //拼接in条件语句          String s = "";          for(int i = 0; i < deptIdList.size();i++){                if(i!=(deptIdList.size()-1)){                      s += deptIdList.get(i) + ",";                }else{                      s += deptIdList.get(i);                }          }          String sql = " and " + condition + " in (" + s + ") ";          return sql;}

更为通用的版本是不用判断deptId是否为1

public String getDeptIdSql(String condition,List<Long> deptIdList){          String s = "";          for(int i = 0; i < deptIdList.size();i++){                if(i!=(deptIdList.size()-1)){                      s += deptIdList.get(i) + ",";                }else{                      s += deptIdList.get(i);                }          }          String sql = " and " + condition + " in (" + s + ") ";          return sql;}

感谢各位的阅读!关于“如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

--结束END--

本文标题: 如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式

本文链接: https://www.lsjlt.com/news/300908.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作