mybatis批量插入报错“Parameter '__frch_item_0' not found. Available parameters are [list]”

本文探讨了使用MyBatis进行批量数据插入的高级技巧,通过解析特定的SQL语句,重点分析了参数类型和集合元素遍历可能导致的问题。文章详细介绍了如何确保传入参数正确并避免空值错误,对于提升数据库操作效率具有重要意义。

原sql:


<select id="queryList" parameterType="java.util.List" >
    insert into table1(column1,column2,column3,column4,column5)
    (
    <foreach collection="list" index="index" item="item"  separator="union all" >
        select 
            #{item.column1},
            #{item.column2},
            #{item.column3},
            #{item.column4},
            #{item.column5}
        from dual    
     </foreach>
    )
</select>

主要分析两点可能的原因:

1、检查传的参数是否是list,parameterType是否为java.util.List。

2、检查foreach遍历的item是否有为空的参数,我遇到的就是这种情况导致的。

public Object intercept(final Invocation invocation) throws Throwable { // 检查表名替换开关是否开启(处理null值情况) Boolean tableReplaceEnabled = configParam.getTableReplaceEnabled(); if (tableReplaceEnabled == null || !tableReplaceEnabled) { log.info("表名替换开关关闭:{}", tableReplaceEnabled); return invocation.proceed(); } log.info("表名替换开关打开:{}", tableReplaceEnabled); // 获取原始SQL Object[] args = invocation.getArgs(); MappedStatement mappedStatement = (MappedStatement) args[0]; Object parameter = args[1]; BoundSql boundSql = mappedStatement.getBoundSql(parameter); String originalSql = boundSql.getSql(); // 检查是否包含需要替换的表名 if (originalSql.contains(ORIGINAL_TABLE_NAME)) { // 执行表名替换 String replacedSql = originalSql.replace(ORIGINAL_TABLE_NAME, TARGET_TABLE_NAME); log.info("表名替换完成,原始SQL:{},替换后SQL:{}", originalSql, replacedSql); //重新生成一个BoundSql对象,确保参数映射正确传递 // 关键:使用原始的parameter对象,这样MyBatis会自动处理批量操作的参数绑定 BoundSql bs = new BoundSql(mappedStatement.getConfiguration(), replacedSql, boundSql.getParameterMappings(), parameter); //重新生成一个MappedStatement对象 MappedStatement newMs = copyMappedStatement(mappedStatement, new BoundSqlSqlSource(bs)); //赋回给实际执行方法所需的参数中 args[0] = newMs; } // 继续执行原始查询 return invocation.proceed(); }这段mybatis拦截器代码执行报错Parameter '__frch_item_0' not found. Available parameters are [request, param1],是什么原因,如何解决
最新发布
11-08
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值