如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式
发表于:2024-10-20 作者:千家信息网编辑
千家信息网最后更新 2024年10月20日,这篇文章给大家分享的是有关如何使用Mybatis注解方式完成输入参数为list的SQL语句拼接方式的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Mybatis注解完成输入参
千家信息网最后更新 2024年10月20日如何使用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安全错误
数据库的锁怎样保障安全
网络安全条例规定
服务器商排名
第一章互联网软件开发过程概述
魔兽平台提示服务器存档保存失败
计算机软件开发专业主要课程
湖南省财政网络安全检查
校园网络安全信息手抄报
浪潮滴滴服务器招标
网络安全是一个什么
魔域数据库修改
测试系统服务器时间如何修改
2017华为软件开发工具
缓存dns服务器
收废品软件开发是哪一年成立
单片机软件开发语言的选择
重庆电脑软件开发机构
珺如阀门互联网科技
做好医院网络安全总结
计算机网络技术专业好吗
两个网站可以用一个数据库
如何正确使用网络确保网络安全
湛江分布式服务器咨询
房山ibm服务器回收价格行情
程序发送短信要存数据库吗
数据库中查询部门的基本信息
锡山软件开发商在线咨询
规范服务器
数据库应用与技术pdf
南宁市任尔行网络技术有限公司
网络安全课后的答案