Mybatis注解方式完成输入参数为list的SQL语句拼接方式
Mybatis注解完成输入参数为list的SQL语句拼接
首先将list集合拼接成一个"1,2,3,4"格式的字符串
然后将这个字符串封装到一个类中:TyreInfoIdStr

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

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

拼接查询条件为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;
}
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
解决java.lang.NullPointerException报错以及分析出现的几种原因
这篇文章介绍了解决java.lang.NullPointerException报错的方法,以及分析出现的几种原因。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-12-12
SpringBoot中的@EnableConfigurationProperties注解详细解析
这篇文章主要介绍了SpringBoot中的@EnableConfigurationProperties注解详细解析,如果一个配置类只配置@ConfigurationProperties注解,而没有使用@Component或者实现了@Component的其他注解,那么在IOC容器中是获取不到properties 配置文件转化的bean,需要的朋友可以参考下2024-01-01
Mac OS X 下 IntelliJ IDEA、jEdit 等 Java 程序中文标点输入无效的完美解决方法
Mac OS X 下基于 Java 的程序会出现中文标点输入无效的问题,在中文输入法状态,可以输入中文字,但输入中文标点最后上去的是英文标点.这篇文章主要介绍了Mac OS X 下 IntelliJ IDEA、jEdit 等 Java 程序中文标点输入无效的完美解决方法,需要的朋友可以参考下2016-10-10
SpringBoot3整合 Elasticsearch 8.x 使用Repository构
我们构建了一个完整的 Spring Boot 3 和 Elasticsearch 8.x 的增删改查示例应用,使用 Spring Data Elasticsearch Repository,我们能够快速实现对 Elasticsearch 的基本 CRUD 操作,简化了开发流程,希望这个示例能够帮助你理解如何在项目中有效使用 Elasticsearch!2024-11-11
IntelliJ IDEA(或者JetBrains PyCharm)中弹出"IntelliJ IDEA License
今天小编就为大家分享一篇关于IntelliJ IDEA(或者JetBrains PyCharm)中弹出"IntelliJ IDEA License Activation"的解决办法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧2018-10-10


最新评论