如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式
发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,这篇文章给大家分享的是有关如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Mybatis注解完成输入参
千家信息网最后更新 2025年11月08日如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式
这篇文章给大家分享的是有关如何使用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(ListdeptIdList){ Iterator 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,ListdeptIdList){ Iterator 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,ListdeptIdList){ 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语句拼接方式"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
语句
方式
函数
条件
参数
注解
输入
字符
字符串
查询
内容
方法
更多
篇文章
部门
不错
复杂
实用
不用
变量
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
软件开发项目初验收
华为数据库pg增强版
天眼查互联网科技
微软云服务器价格按需分配
微粒贷部署了多少台服务器
国外网络技术软件
普陀区车载网络技术创新服务
韶关信息网络安全培训哪里好
男生学会计还是网络技术
网络安全产品手绘简笔画
数据库自动生成主键
软件开发技术专业弊端
湖南采购管理软件开发
儿童网络安全知识大全
寻找手机软件开发合作
当下最流行的网络技术
重庆云阳生鲜软件开发
首届网络安全周是在几几年
达梦数据库占内存
初三网络安全教育手抄报
网络安全知识图片板报
青浦区进口网络技术创造辉煌
渠道无忧网络技术有限公司
服务器安全检查有哪些
2020网络安全周开幕
西昌软件开发专业
网络安全少年手抄报
以前人人网的数据库
武汉有哪些大的软件开发公司
2019工资核算免费数据库