欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

mybatis数组和集合的长度判断及插入方式

时间:2022-10-24 08:53:19|栏目:JAVA代码|点击:

mybatis数组和集合的长度判断及插入

1、在使用foreach的是collection属性

该属性是必须指定的,但是在不同情况下,该属性的值是不一样的

主要有一下4种情况: 

  • 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list .
  • 如果传入的是单参数且参数类型是非list的Collection的时候,collection属性值为collection .
  • 如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array
  • 如果dao层指定了param的name,或者dao层传的是map,collection里为param的name或map的key
DefaultSqlSession
private Object wrapCollection(final Object object) {
    if (object instanceof Collection) {
      StrictMap<Object> map = new StrictMap<Object>();
      map.put("collection", object);
      if (object instanceof List) {
        map.put("list", object);
      }
      return map;
    } else if (object != null && object.getClass().isArray()) {
      StrictMap<Object> map = new StrictMap<Object>();
      map.put("array", object);
      return map;
    }
    return object;
  }

2、判断长度

集合:<if test="arr != null and arr.size() > 0">

数组:<if test="col != null and col .length > 0">

mybatis数组与集合判断非空和长度

数组判断

参数object为数组Object[]时。先判断是否为null,不为null则判断数组长度object.length是否大于0即可。

    <if test="object!=null and object.length>0">
        <yourSql>
    </if>

集合判断

参数object为集合List<Object>时,先判断是否为null,不为null则判断集合长度object.size()是否大于0即可。

    <if test="object!=null and object.size()>0">
        <yourSql>
    </if>

上一篇:java若依框架集成redis缓存详解

栏    目:JAVA代码

下一篇:使用@JsonFormat的一个坑及解决

本文标题:mybatis数组和集合的长度判断及插入方式

本文地址:http://www.codeinn.net/misctech/217221.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有