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

目录
  • 接收以逗号分隔的字符串批量查询
  • 如何相互转换逗号分隔的字符串和List
    • 将逗号分隔的字符串转换为List
    • 将List转换为逗号分隔符

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

<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(), ",");
            }
    }

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • MyBatis 动态拼接Sql字符串的问题

    MyBatis 的一个强大的特性之一通常是它的动态 SQL 能力.如果你有使用 JDBC 或其他 相似框架的经验,你就明白条件地串联 SQL 字符串在一起是多么的痛苦,确保不能忘了空格或在列表的最后省略逗号.动态 SQL 可以彻底处理这种痛苦. 动态SQL MyBatis的动态SQL,解决了SQL字符串拼接的痛苦. 1.if <select id="findActiveBlogWithTitleLike" parameterType="Blog" result

  • mybatis分割字符串并循环,实现in多个参数的操作

    mybatis分割字符串并循环,实现in多个参数 mybatis xml代码: <select id="selectInXh" resultMap="BaseResultMap" parameterType="java.lang.String"> select * from carinfo where xh in <if test="param1 != null and param1 != ''"> &

  • mybatis in查询传入String方式

    mybatis in查询传入String 在使用 mybaits 进行 in 查询时,传入String,如1,2,3,发现查询的结果并非我们想要的 这是因为#{}编译完自动加双引号"" 也就是变成in ("1,2,3") 如果想要获得我们想要的结果,可以使用${},编译完是这样的 in (1,2,3) 例如,查询铃音库中多首铃音的总数量 <select id="getProgsResourceCount" resultType="

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

    目录 接收以逗号分隔的字符串批量查询 如何相互转换逗号分隔的字符串和List 将逗号分隔的字符串转换为List 将List转换为逗号分隔符 接收以逗号分隔的字符串批量查询 <IF test = " supplierIds !=null and supplierIds.indexOf(',') != -1  ">      AND msd.supplier_id NOT IN      <foreach collection = "supplierIds.sp

  • myBatis的mapper映射文件之批量处理方式

    目录 mybatis批量插入 mybatis批量删除 mybatis批量修改 myBatis mapper文件详解 Mapper文件中包含的元素有 mybatis支持别名: jdbcType与JavaType的映射关系 #mybatis常见批量处理 在开发当中,可能经常会遇到批量处理这种情况,一般都再在java层面进行, 其本质是节省数据库连接打开关闭的的次数,占用更少的运行内存. mybatis批量插入 <insert id="saveFeeRuleList" useGener

  • Mybatis传参为逗号分隔的字符串情形进行in条件查询方式

    目录 传参为逗号分隔的字符串情形进行in条件查询 后端只需要做如下调整 根据逗号分隔的id查询 传参为逗号分隔的字符串情形进行in条件查询 在业务变更需支持多条件查询,在改动最小的情况下,实现方式就是只改mapper.xml,这时,可让前端逗号分隔传参 后端只需要做如下调整 <if test="paramXXX!= null and paramXXX!= ''">   and t.paramXXX in     <foreach item="item&quo

  • sql查询结果列拼接成逗号分隔的字符串方法

    背景:做SQL查询时会经常需要,把查询的结果拼接成一个字符串. 解决方法: 通过group_concat函数 拼接的结果很长,导致拼接结果显示不全,可以通过以下方法解决. 在每次查询前执行SET SESSION group_concat_max_len = 10240; 或者SET GLOBALgroup_concat_max_len = 10240; 使得查询结果值变大. 补充:SQL server 的 拼接SQL如下: selectstuff(( select ','+ requestid

  • Mybatis如何根据List批量查询List结果

    目录 根据List批量查询List结果 mapper接口 mapper.xml文件 根据多条件List查询 mapper文件 DAO片段 根据List批量查询List结果 mapper接口 /**  * 根据剧典id list查询剧典  */ public List<Drama> selectByIds(@Param("dramaIds")List<Long> dramaIds); mapper.xml文件 <!-- 根据剧典id list查询剧典 --&

  • mybatis框架的xml映射文件常用查询指南

    使用mybatis框架时,那必然会有对数据库的查询语句的编写,所以这篇文章希望可以帮助到你. 什么是Mybatis框架? MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录. 如何使用?

  • 使用Mybatis接收Integer参数的问题

    目录 Mybatis接收Integer参数 解决办法 Mybatis在使用Integer类型 当传人mybatis构成sql语句时 Mybatis接收Integer参数 最近在做项目的时候,在mybatis中用标签判断分页参数时,出现了问题. <if test="startRow != null and startRow != '' and selectRow != null and selectRow != ''">     LIMIT #{startRow},#{sel

  • 用NodeJS实现批量查询地理位置的经纬度接口

    实现步骤 1. 查询接口 网站上这种类型的接口还不少,笔者直接找了百度地图的接口做,接口文档,调用的API是Geocoding API中的地理编码服务 请求示例:对北京市百度大厦进行地理编码查询 http://api.map.baidu.com/geocoder/v2/?ak=E4805d16520de693a3fe707cdc962045&callback=renderOption&output=json&address=百度大厦&city=北京市 这里面需要一个ak参数

  • MyBatis实践之动态SQL及关联查询

    序言 MyBatis,大家都知道,半自动的ORM框架,原来叫ibatis,后来好像是10年apache软件基金组织把它托管给了goole code,就重新命名了MyBatis,功能相对以前更强大了.它相对全自动的持久层框架Hibernate,更加灵活,更轻量级,这点我还是深有体会的. MyBatis的一个强大特性之一就是动态SQL能力了,能省去我们很多串联判断拼接SQL的痛苦,根据项目而定,在一定的场合下使用,能大大减少程序的代码量和复杂程度,不过还是不是过度太过复杂的使用,以免不利于后期的维护

  • MyBatis学习教程(五)-实现关联表查询方法详解

    一.一对一关联  1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关系就是一种一对一的关系. CREATE TABLE teacher( t_id INT PRIMARY KEY AUTO_INCREMENT, t_name VARCHAR() ); CREATE TABLE class( c_id INT PRIMARY KEY AUTO_INCREMENT, c_name VAR

随机推荐