轻量级前端框架助力开发者提升项目效率与性能
752
2022-11-05
mybatis接收以逗号分隔的字符串批量查询方式
目录接收以逗号分隔的字符串批量查询如何相互转换逗号分隔的字符串和List将逗号分隔的字符串转换为List将List转换为逗号分隔符
接收以逗号分隔的字符串批量查询
AND msd.supplier_id NOT IN
OPEN = "(" SEPARATOR = "," CLOSE = ")"> #{item}
OPEN = "(" SEPARATOR = "," CLOSE = ")">
#{item}
AND msd.supplier_id != #{supplierIds}
直接粘贴进去,上面部分实现循环查询,下面是针对单个字符的补充(因为单个字符不存在逗号)
如何相互转换逗号分隔的字符串和List
如果程序员想实现某种功能,有两条路可以走。一条就是自己实现,一条就是调用别人的实现,别人的实现就是所谓的API。而且大多数情况下,好多“别人”都 实现了这个功能。程序员有不得不在这其中选择。大部分情况下,程序员就会知道哪个用哪个,先看到哪个用哪个。到最后,在实际项目中,同样的功能会调用五花 八门的API。我在公司的项目中http://就看到了这种情况。其实,也无可厚非,我相信好多项目都是这个样子。我们不可能要求程序员都用同一种方法。程序员可能会有 不同的好恶。为了让程序员能快乐自由地编程,就随他去吧!因为程序员感觉自由的时候,感觉快乐的时候,正是他们生产力最高的时候。
不扯淡了。回归正题,到底这些不同的实现方法或者API真的就没有高低贵贱之分?以我遇到这个逗号分隔字符串转List为例,探讨探讨:
注:下面的代码并不能保证能运行,可能需要稍微的修改。
将逗号分隔的字符串转换为List
方法 1: 利用JDK的Arrays类
String str = "a,b,c";
List
方法2:利用Guava的Splitter
String str = "a, b, c";
http://List
方法3:利用Apache Commons的StringUtils (只是用了split)
String str = "a,b,c";
List
方法4:利用Spring Framework的StringUtils
String str = "a,b,c";
List
将List转换为逗号分隔符
方法 1:利用JDK(好像没有很好的方法,需要一步一步实现)
NA
方法2:利用Guava的Joiner
List
list.add("a");
list.add("b");
list.add("c");
String str = Joiner.on(",").join(list);
方法3:利用Apache Commons的StringUtils
List
list.add("a");
list.add("b");
list.add("c");
String str = StringUtils.join(list.toArray(), ",");
方法4:利用Spring Framework的StringUtils
List
list.add("a");
list.add("b");
list.add("c");
String str = StringUtils.collectionToDelimitedString(list, ",");
比较下来,我的观点就是Guava库更灵活,适用面更广。项目中如果没有引入Guava的话,那就加上它。
//拼接所有字符串
public String getAllIdByUserMhttp://obile( List
StringBuilder userMobileIdString = new StringBuilder();
//拼接字符串 userMobile productId
if( userMobile.size() <= 0){
return "";
}else{
for(nrnMJkIString item:userMobile){
userMobileIdString.append(item + ",");
}
return org.apache.commons.lang.StringUtils.removeEnd(userMobileIdString.toString(), ",");
}
}
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~