mybatis处理集合、循环、数组和in等语句的使用

http://www.suyunyou.com/aid5.html参考
mybatis处理集合、循环、数组和in等语句的使用

在mybatis 批量执行sql时,报错 java.util.list can't find. 原因:collection 属性定义错误。

List a=ArrayList.asList(str); sql 遍历数据a,  a为一个list,所以 collection 属性要定义成 list;

String [] ids=str.split(","); sql遍历数据ids,ids 是一个数组,所以collection属性要定义成 array;


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

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

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

3.     如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,实际上如果你在传入参数的时候,在breast里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key.

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

下面看看代码把!

实体bean:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
package com.huaat.weibo.vo;
 
import java.io.Serializable;
 
/**
  * 我的微博实体
  * <a href="http://my.oschina.net/arthor" target="_blank" rel="nofollow">@author</a> 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为实体]:
?
1
2
3
4
5
6
7
<!-- 删除微博 -->
     < 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。

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

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

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

close表示以什么结束.

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

?
1
2
3
4
5
     /**
  * 删除微博
  * @param myWeibo
  */
public abstract void delMyWeibo(MyWeibo myWeibo);

这样就解决这个问题了~

原文来自:http://www.suyunyou.com/aid5.html



在Mybatis的xml配置中使用集合,主要是用到了foreach动态语句。

foreach的参数:
foreach元素的属性主要有 item,index,collection,open,separator,close。
item表示集合中每一个元素进行迭代时的别名.
index指 定一个名字,用于表示在迭代过程中,每次迭代到的位置.
open表示该语句以什么开始,separator表示在每次进行迭代之间以什么符号作为分隔 符.
close表示以什么结束。


1. Mybatis生成select * from table where id in(1,2,...,n)语句的查询

我们一般的做法是在方法的参数处指定传入的参数名称,在xml中使用的时候,集合的名称要和方法的Param的名称一致,这样便于阅读和理解,然后是在对应的xml文件中使用foreach循环。

java代码如下:

public abstract List<Model> findByIds(@Param("ids")List<Integer> ids);

对应的xml代码如下:

select * from table
<where>
    id in <foreach collection="ids" item="item" index="index" 
open="(" separator="," close=")">#{item}</foreach>
</where>

2.Mybatis保存多条记录

我们同样是通过foreach的方法来实现,这里我们巧妙的利用了sql的语法规则用Mybatis的foreach动态语句来处理。

java代码:

public abstract void saves(@Param("tables")List<Model> tables);

xml代码:

insert into table(name,addtime) values
<foreach collection="tables" item="item" index="index" separator=",">  
    (#{item.name},#{item.addtime})
</foreach>

以上方法Mybatis会帮我们进行sql注入拦截,Mybatis如果采用#{xxx}的形式设置参数,Mybatis会进行sql注入的过滤。如果采用的是${xxx},Mybatis不会进行sql注入过滤,而是直接将参入的内容输出为sql语句。

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值