广告
返回顶部
首页 > 资讯 > 精选 >mybatis接收以逗号分隔的字符串批量查询方法
  • 500
分享到

mybatis接收以逗号分隔的字符串批量查询方法

2023-06-28 19:06:30 500人浏览 独家记忆
摘要

本篇内容介绍了“mybatis接收以逗号分隔的字符串批量查询方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!接收以逗号分隔的字符串批量查询

本篇内容介绍了“mybatis接收以逗号分隔的字符串批量查询方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

接收以逗号分隔的字符串批量查询

<IF test = " supplierIds !=null and supplierIds.indexOf(',') != -1  ">     AND msd.supplier_id NOT IN     <foreach collection = "supplierIds.split(',')" item = "item"         OPEN = "(" SEPARATOR = "," CLOSE = ")">              #{item}    </foreach></IF><IF test = "supplierIds !=null and supplierIds.indexOf(',') == -1">     AND msd.supplier_id != #{supplierIds}</IF>

直接粘贴进去,上面部分实现循环查询,下面是针对单个字符的补充(因为单个字符不存在逗号)

如何相互转换逗号分隔的字符串和List

如果程序员想实现某种功能,有两条路可以走。一条就是自己实现,一条就是调用别人的实现,别人的实现就是所谓的api。而且大多数情况下,好多“别人”都 实现了这个功能。程序员有不得不在这其中选择。大部分情况下,程序员就会知道哪个用哪个,先看到哪个用哪个。到最后,在实际项目中,同样的功能会调用五花 八门的API。我在公司的项目中就看到了这种情况。其实,也无可厚非,我相信好多项目都是这个样子。我们不可能要求程序员都用同一种方法。程序员可能会有 不同的好恶。为了让程序员能快乐自由地编程,就随他去吧!因为程序员感觉自由的时候,感觉快乐的时候,正是他们生产力最高的时候。

不扯淡了。回归正题,到底这些不同的实现方法或者API真的就没有高低贵贱之分?以我遇到这个逗号分隔字符串转List为例,探讨探讨:

注:下面的代码并不能保证能运行,可能需要稍微的修改。

将逗号分隔的字符串转换为List

方法 1: 利用jdk的Arrays类

String str = "a,b,c";List<String> result = Arrays.asList(str.split(","));

方法2:利用Guava的Splitter

    String str = "a, b, c";    List<String> result = Splitter.on(",").trimResults().splitToList(str);

方法3:利用Apache Commons的StringUtils (只是用了split)

  String str = "a,b,c";    List<String> result = Arrays.asList(StringUtils.split(str,","));

方法4:利用spring Framework的StringUtils

    String str = "a,b,c";    List<String> str = Arrays.asList(StringUtils.commaDelimitedListToStringArray(str));

将List转换为逗号分隔符

方法 1:利用JDK(好像没有很好的方法,需要一步一步实现)

NA

方法2:利用Guava的Joiner

    List<String> list = new ArrayList<String>();    list.add("a");    list.add("b");    list.add("c");    String str = Joiner.on(",").join(list);

方法3:利用Apache Commons的StringUtils

    List<String> list = new ArrayList<String>();    list.add("a");    list.add("b");    list.add("c");    String str = StringUtils.join(list.toArray(), ",");

方法4:利用Spring Framework的StringUtils

List<String> list = new ArrayList<String>();list.add("a");list.add("b");list.add("c");String str = StringUtils.collectionToDelimitedString(list, ",");

比较下来,我的观点就是Guava库更灵活,适用面更广。项目中如果没有引入Guava的话,那就加上它。

  //拼接所有字符串    public String getAllIdByUserMobile( List<String> userMobile) throws Exception {           StringBuilder userMobileIdString = new StringBuilder();           //拼接字符串 userMobile productId            if( userMobile.size() <= 0){                return "";            }else{                for(String item:userMobile){                    userMobileIdString.append(item + ",");                }                return org.apache.commons.lang.StringUtils.removeEnd(userMobileIdString.toString(), ",");            }    }

“mybatis接收以逗号分隔的字符串批量查询方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: mybatis接收以逗号分隔的字符串批量查询方法

本文链接: https://www.lsjlt.com/news/321032.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作