使用ibatis的iterate标签实现批量插入

ibatis批量插入(使用iterate标签)

1、要注意版本是否支持foreach,我使用的版本就不支持。如果不支持,会报错,叫你必须指定foreach元素类型。

2、使用iterate的List时,即 parameterClass="java.util.List",总是报错:Excepted java.util.List, but get User.一直没找到是哪配置错误。。。。。?

3、使用iterate的Map时的注意事项

对象User具有属性Id ,name,age,sex
UserDao.javapublic void insertBatch(Map<String,List<USer>> userMap);
UserDao.xml

<insert id="insertBatch" parameterClass="java.util.HashMap">

    insert into user_table(ID,NAME,AGE,SEX) values

    <iterate conjunction="," property="userList">

       ( #userList[].id:varchar#,

         #userList[].name:varchar#,

        #userList[].age:integer#,

        #userList[].sex:INTEGER#)

    </iterate>

</insert>

UserService.java

在使用iterate的map时,注意Map的Key与Property属性对应:

 

Map<String,List<User>> userMap=new HashMap<String,List<User>>();

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

list.add(new User("111","zhangsan",22,1));

list.add(new User("222","lisi",23,0));

...

userMap.put("userList",list);

userDao.insertBatch(userMap);

老项目维护,项目框架里是ibatis,所以,只能用ibatis。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值