MyBatis的10种用法

用来循环容器的标签forEach,查看例子【MyBatis的10种用法】foreach元素的属性主要有item,index,collection,open,separator,close 。

  • item:集合中元素迭代时的别名,
  • index:集合中元素迭代时的索引
  • open:常用语where语句中,表示以什么开始,比如以'('开始
  • separator:表示在每次进行迭代时的分隔符,
  • close 常用语where语句中,表示以什么结束,
在使用foreach的时候最关键的也是最容易出错的就是collection属性,该属性是必须指定的,但是在不同情况下,该属性的值是不一样的,主要有以下3种情况:
  • 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list .
  • 如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array .
  • 如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,实际上如果你在传入参数的时候,在MyBatis里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key.
针对最后一条,我们来看一下官方说法:
注意 你可以将一个 List 实例或者数组作为参数对象传给 MyBatis,当你这么做的时候,MyBatis 会自动将它包装在一个 Map 中并以名称为键 。List 实例将会以“list”作为键,而数组实例的键将是“array” 。
所以,不管是多参数还是单参数的list,array类型,都可以封装为map进行传递 。如果传递的是一个List,则mybatis会封装为一个list为key,list值为object的map,如果是array,则封装成一个array为key,array的值为object的map,如果自己封装呢,则colloection里放的是自己封装的map里的key值
//mApper中我们要为这个方法传递的是一个容器,将容器中的元素一个一个的//拼接到xml的方法中就要使用这个forEach这个标签了public List<Entity> queryById(List<String> userids);//对应的xml中如下<select id="queryById" resultMap="BaseReslutMap" >select * FROM entitywhere id in<foreach collection="userids" item="userid" index="index" open="(" separator="," close=")">#{userid}</foreach></select>concat模糊查询//比如说我们想要进行条件查询,但是几个条件不是每次都要使用,那么我们就可以//通过判断是否拼接到sql中<select id="queryById" resultMap="BascResultMap" parameterType="entity">SELECT *from entity<where><if test="name!=null">name like concat('%',concat(#{name},'%'))</if></where></select>choose (when, otherwise)标签choose标签是按顺序判断其内部when标签中的test条件出否成立,如果有一个成立,则 choose 结束 。当 choose 中所有 when 的条件都不满则时,则执行 otherwise 中的sql 。类似于JAVA 的 switch 语句,choose 为 switch,when 为 case,otherwise 则为 default 。
例如下面例子,同样把所有可以限制的条件都写上,方便使用 。choose会从上到下选择一个when标签的test为true的sql执行 。安全考虑,我们使用where将choose包起来,防止关键字多于错误 。
<!--choose(判断参数) - 按顺序将实体类 User 第一个不为空的属性作为:where条件 --><select id="getUserList_choose" resultMap="resultMap_user" parameterType="com.yiibai.pojo.User">SELECT *FROM User u<where><choose><when test="username !=null ">u.username LIKE CONCAT(CONCAT('%', #{username, jdbcType=VARCHAR}),'%')</when ><when test="sex != null and sex != '' ">AND u.sex = #{sex, jdbcType=INTEGER}</when ><when test="birthday != null ">AND u.birthday = #{birthday, jdbcType=DATE}</when ><otherwise></otherwise></choose></where></select>selectKey 标签在insert语句中,在Oracle经常使用序列、在MySQL中使用函数来自动生成插入表的主键,而且需要方法能返回这个生成主键 。使用myBatis的selectKey标签可以实现这个效果 。下面例子,使用mysql数据库自定义函数nextval('student'),用来生成一个key,并把他设置到传入的实体类中的studentId属性上 。所以在执行完此方法后,便可以通过这个实体类获取生成的key 。
<!-- 插入学生 自动主键--><insert id="createStudentAutoKey" parameterType="liming.student.manager.data.model.StudentEntity" keyProperty="studentId"><selectKey keyProperty="studentId" resultType="String" order="BEFORE">select nextval('student')</selectKey>INSERT INTO STUDENT_TBL(STUDENT_ID,STUDENT_NAME,STUDENT_SEX,STUDENT_BIRTHDAY,STUDENT_PHOTO,CLASS_ID,PLACE_ID)VALUES (#{studentId},#{studentName},#{studentSex},#{studentBirthday},#{studentPhoto, javaType=byte[], jdbcType=BLOB, typeHandler=org.Apache.ibatis.type.BlobTypeHandler},#{classId},#{placeId})</insert>


推荐阅读