mybatis接收以逗号分隔的字符串批量查询方法
mybatis接收以逗号分隔的字符串批量查询方法
本篇内容介绍了“mybatis接收以逗号分隔的字符串批量查询方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
接收以逗号分隔的字符串批量查询
<IFtest="supplierIds!=nullandsupplierIds.indexOf(',')!=-1">ANDmsd.supplier_idNOTIN<foreachcollection="supplierIds.split(',')"item="item"OPEN="("SEPARATOR=","CLOSE=")">#{item}</foreach></IF><IFtest="supplierIds!=nullandsupplierIds.indexOf(',')==-1">ANDmsd.supplier_id!=#{supplierIds}</IF>
直接粘贴进去,上面部分实现循环查询,下面是针对单个字符的补充(因为单个字符不存在逗号)
如何相互转换逗号分隔的字符串和List
如果程序员想实现某种功能,有两条路可以走。一条就是自己实现,一条就是调用别人的实现,别人的实现就是所谓的API。而且大多数情况下,好多“别人”都 实现了这个功能。程序员有不得不在这其中选择。大部分情况下,程序员就会知道哪个用哪个,先看到哪个用哪个。到最后,在实际项目中,同样的功能会调用五花 八门的API。我在公司的项目中就看到了这种情况。其实,也无可厚非,我相信好多项目都是这个样子。我们不可能要求程序员都用同一种方法。程序员可能会有 不同的好恶。为了让程序员能快乐自由地编程,就随他去吧!因为程序员感觉自由的时候,感觉快乐的时候,正是他们生产力最高的时候。
不扯淡了。回归正题,到底这些不同的实现方法或者API真的就没有高低贵贱之分?以我遇到这个逗号分隔字符串转List为例,探讨探讨:
注:下面的代码并不能保证能运行,可能需要稍微的修改。
将逗号分隔的字符串转换为List
方法 1: 利用JDK的Arrays类
Stringstr="a,b,c";List<String>result=Arrays.asList(str.split(","));
方法2:利用Guava的Splitter
Stringstr="a,b,c";List<String>result=Splitter.on(",").trimResults().splitToList(str);
方法3:利用Apache Commons的StringUtils (只是用了split)
Stringstr="a,b,c";List<String>result=Arrays.asList(StringUtils.split(str,","));
方法4:利用Spring Framework的StringUtils
Stringstr="a,b,c";List<String>str=Arrays.asList(StringUtils.commaDelimitedListToStringArray(str));
将List转换为逗号分隔符
方法 1:利用JDK(好像没有很好的方法,需要一步一步实现)
NA
方法2:利用Guava的Joiner
List<String>list=newArrayList<String>();list.add("a");list.add("b");list.add("c");Stringstr=Joiner.on(",").join(list);
方法3:利用Apache Commons的StringUtils
List<String>list=newArrayList<String>();list.add("a");list.add("b");list.add("c");Stringstr=StringUtils.join(list.toArray(),",");
方法4:利用Spring Framework的StringUtils
List<String>list=newArrayList<String>();list.add("a");list.add("b");list.add("c");Stringstr=StringUtils.collectionToDelimitedString(list,",");
比较下来,我的观点就是Guava库更灵活,适用面更广。项目中如果没有引入Guava的话,那就加上它。
//拼接所有字符串publicStringgetAllIdByUserMobile(List<String>userMobile)throwsException{StringBuilderuserMobileIdString=newStringBuilder();//拼接字符串userMobileproductIdif(userMobile.size()<=0){return"";}else{for(Stringitem:userMobile){userMobileIdString.append(item+",");}returnorg.apache.commons.lang.StringUtils.removeEnd(userMobileIdString.toString(),",");}}
“mybatis接收以逗号分隔的字符串批量查询方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注恰卡编程网网站,小编将为大家输出更多高质量的实用文章!
推荐阅读
-
MyBatis和jeesite多表查询的方法
MyBatis和jeesite多表查询的方法这篇文章主要介绍了My...
-
Mybatis怎么实现ResultMap结果集
-
SpringBoot MyBatis怎么快速入门
-
怎么用springboot+mybatis plus实现树形结构查询
怎么用springboot+mybatisplus实现树形结构查询...
-
springboot中怎么实现mybatis多数据源动态切换
springboot中怎么实现mybatis多数据源动态切换这篇“...
-
基于SpringBoot加载Mybatis的TypeAlias问题怎么解决
基于SpringBoot加载Mybatis的TypeAlias问题怎么解决...
-
怎么用Springboot+mybatis-plus+注解实现数据权限隔离
怎么用Springboot+mybatis-plus+注解实现数据权限隔离...
-
Springboot+Mybatis中怎么实现typeAliasesPackage正则扫描
Springboot+Mybatis中怎么实现typeAliasesPackage正则扫描...
-
springBoot mybatis包扫描问题怎么解决
springBootmybatis包扫描问题怎么解决这篇文章主要...
-
Mybatis全局配置及映射关系怎么实现