mybatis处理集合和循环数组问题

   在使用foreach的时候最容易出错的就是collection属性,该属性是必须指定的,在不一样状况 下,该属性的值是不同的,主要有一下3种状况:html

1.     若是传入的是单参数且参数类型是一个List的时候,collection属性值为listjava

2.     若是传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array数组

3.     若是传入的参数是多个的时候,咱们就须要把它们封装成一个Map了,固然单参数也能够封装成map,实际上若是你在传入参数的时候,在breast里面也是会把它封装成一个Map的,map的key就是参数名,因此这个时候collection属性值就是传入的List或array对象在本身封装的map里面的key.mybatis

    我采用mybatis直接将数组看成参数传入老是出现错误,说找不到参数,也按照上述的条件一一尝试结果仍是不行,我想可能出现这个问题的缘由是mybatis的版本问题。后来采用传入一个实体,在实体里面定义数组的方法。而后操做,这样就不出错了。此方法虽为下册,但也能够应付一些关键问题。this

下面看看代码把!.net

实体bean:code

package com.huaat.weibo.vo;

import java.io.Serializable;

/**
 * 个人微博实体
 * @author jing.yue
 * @version 2012/07/17 1.0.0
 */
public class MyWeibo implements Serializable {

	private static final long serialVersionUID = 754681127580984228L;

	private String[] fileNames;
	private String[] fileUrls;

	public String[] getFileNames() {
		return fileNames;
	}
	public void setFileNames(String[] fileNames) {
		this.fileNames = fileNames;
	}
	public String[] getFileUrls() {
		return fileUrls;
	}
	public void setFileUrls(String[] fileUrls) {
		this.fileUrls = fileUrls;
	}

}

下面为mybatis的配置文件[myWeibo为实体]:htm

<!-- 删除微博 -->
	<delete id="delMyWeibo" parameterType="myWeibo">
		delete from my_weibo where weibo_id in
		<foreach item="item" index="index" collection="fileUrls" open="(" separator="," close=")">
			#{item}
		</foreach>
	</delete>

解释下foreach的参数:对象

foreach元素的属性主要有 item,index,collection,open,separator,close。get

item表示集合中每个元素进行迭代时的别名.

index指 定一个名字,用于表示在迭代过程当中,每次迭代到的位置.

open表示该语句以什么开始,separator表示在每次进行迭代之间以什么符号做为分隔 符.

close表示以什么结束.

至于调用这个方法的代码:

/**
	 * 删除微博
	 * @param myWeibo
	 */
	public abstract void delMyWeibo(MyWeibo myWeibo);

这样就解决这个问题了~

原文来自:https://www.52jingya.com/aid5.html

相关文章
相关标签/搜索