ibatis实现Iterate的使用

ibatis实现Iterate的使用


1、用法

<iterate property="serialList" open="(" close=")" conjunction=",">
#serialList[]#
</iterate>


其中  property="" /*可选,
从传入的参数集合中使用属性名去获取值,这个必须是一个List类型,  
否则会出现OutofRangeException,通常是参数使用java.util.Map时才使用,   
如果传入的参数本身是一个java.util.List, 不能只用这个属性.  

conjunction="" /*可选,   
iterate可以看作是一个循环,这个属性指定每一次循环结束后添加的符号,    
比如使每次循环是OR的, 则设置这个属性为OR*/  

open="" /*可选, 循环的开始符号*/  
close="" /*可选, 循环的结束符号*/  
prepend="" /*可选, 加在open指定的符号之前的符号*/  


2、批量删除对象的时候,iterate不要property属性
<delete id="delStudybook" parameterClass="java.util.List">


delete FROM STUDYBOOK WHERE ID IN


<iterate conjunction=","  property="aaa"


open="(" close=")">


 #aaa[]#


</iterate>


</delete>

注意要property的错误




Caused by: com.ibatis.common.beans.ProbeException: Error getting ordinal list from JavaBean. Cause java.lang.StringIndexOutOfBoundsException: String index out of range: -1




//另外:如果parameterClass="java.util.List"类型不匹配的话




报错Caused by: java.sql.SQLException: Invalid parameter object type.  Expected 'java.util.Map' but found 'java.util.ArrayList'.

测试:

List<Integer> list=new ArrayList<Integer>();


list.add(1);


list.add(2);




//删除书籍




dao.deleteStudyBook(list);

 public int deleteStudyBook(List<Integer> bookList){




        try {
return this.client.delete("delStudybook",bookList);




} catch (SQLException e) {




e.printStackTrace();




return 0;
}
}

3、批量修改对象,iterate必须包括property属性

<update id="updateUsersIterate" parameterClass="java.util.Map">


update users set user_name=#userInfo.user_name# where user_id in


<iterate property="list" conjunction="," open="(" close=")">


 #list[]#


</iterate>
</update>




注意不要property属性的错误




Cause: com.ibatis.sqlmap.client.SqlMapException: ParameterObject or property was not a Collection, Array or Iterator.

测试:

Map<String,Object> map=new HashMap<String,Object>();




//设置修改的字段




Users user=new Users();


user.setUser_name("aaaaaaaaaaaaaaaaa");


List<Integer> list1=new ArrayList<Integer>();


list1.add(1);
list1.add(2);


map.put("userInfo",user);


map.put("list",list1);


dao.updateUsers(map);

public int updateUsers(Map<String,Object> map){




        try {


return this.client.delete("updateUsersIterate",map);




} catch (SQLException e) {




e.printStackTrace();




return 0;

}


4、Iterate的使用,根据多个匹配条件查询,类似in(a,b,c)

<select id="selectByIterate" parameterClass="java.util.List" resultClass="user">


SELECT * FROM USERS WHERE USER_ID IN


<iterate conjunction="," open="(" close=")">
 #ids[]#
</iterate>


</select>




注意:不要property属性,否则报错。String index out of range: -1




    2. 但是,若参数有多个传入的一个是List,另一个不是,
parameterClass为map/HashMap时,需要property属性区分要遍历的集合。

测试:
public void queryByIterate(List<Integer> ids){


try {


List<Users> list=this.client.queryForList("selectByIterate",ids);


for (Users user : list) {


System.out.println("user====I"+user.toString());


}
} catch (Exception e) {
e.printStackTrace();
}
}


5、批量增加对象

<insert id="BarkInsertUsers" parameterClass="java.util.List">
insert all
<iterate conjunction="">


into users(user_id,user_name,password,address,telephone,email,create_date)


values(#list[].user_id#,#list[].user_name#,#list[].password#,


#list[].address#,#list[].telephone#,#list[].email#,#list[].create_date#)


</iterate>


<!--必须要加上 -->


 select * from dual


</insert>

测试:

List<Users> userList=new ArrayList<Users>();




//方式一:不适用自动增长列(id设置值:#list[].user_id#)




Users user1=new Users(10,"bbbb","bbbb","bbbb","bbbb","bbbb","bbbb");


Users user2=new Users(11,"cccc","cccc","cccc","cccc","cccc","cccc");

userList.add(user1);
userList.add(user2);
dao.barkInsert(userList);


//使用Iterate实现批量插入数据




  public void barkInsert(List<Users> list){
 try {


this.client.insert("BarkInsertUsers",list);


} catch (SQLException e) {


e.printStackTrace();
}



注:Iterate就是为数据传入的是一个list,然后用集合数据完成数据库的增删改查,实现类似批量。


  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
如果在iBatis使用iterate进行批量插入处理,而且表名不确定,需要通过参数传递进SQL语句中,可以使用动态SQL语句和参数映射来实现。 具体步骤如下: 1. 在iBatis的SQL语句中,使用动态SQL语句来拼接表名。可以使用if标签判断表名是否为空,如果为空,则使用默认表名;如果不为空,则拼接传递进来的表名。 ``` <insert id="batchInsert"> INSERT INTO <if test="tableName != null and tableName != ''"> ${tableName} </if> <if test="tableName == null or tableName == ''"> default_table_name </if> (column1, column2, column3) VALUES <iterate property="list" open="(" close=")" conjunction=","> #{item.column1},#{item.column2},#{item.column3} </iterate> </insert> ``` 2. 在iBatis的SqlMapClientTemplate中,将表名作为参数传递进insert方法中,并将参数映射到SQL语句中。 ``` public void batchInsert(String tableName, List<Entity> list) { Map<String, Object> paramMap = new HashMap<>(); paramMap.put("tableName", tableName); paramMap.put("list", list); sqlSessionTemplate.insert("batchInsert", paramMap); } ``` 在这个示例代码中,tableName是需要动态拼接的表名,list是需要插入的数据列表。在batchInsert方法中,将tableName和list封装成Map类型的参数,然后将参数传递进insert方法中,最终参数会被映射到SQL语句中,实现动态拼接表名的功能。 注意,在动态拼接表名时,需要使用${}来引用表名变量,而不是#{}。因为#{}会将表名参数作为字符串进行转义,而${}则不会进行转义,所以可以正确拼接表名。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

powerfuler

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值