[解决]Parameter '__frch_item_0' not found. Available parameters are [list]

mybatis+mysql下批量插入一些问题,在这里记录一下,如下错误信息:

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter '__frch_item_0' not found. Available parameters are [list]

 前来说一下我遇到这个错误的两种情况:

 

要说明情况下,前说一下项目上是怎么使用的.我们一般都在 DAO 里定义一个接口方法,然后在对应的接口 mapper.xml文件中实现相应的 SQL 功能.然后在 services的实现类注入 DAO 再使用.

第一种情况:

在 DAO 中定义了一个批量插入的方法:

 

 int delBatchPasswor(List<String> pwdl);

 在 mapper.xml 中的实现:

	<delete id="delBatchPasswor" parameterType="java.util.List">
		delete from t_gateway_password where gateway_password in
		<foreach collection="list" item="item" open="(" separator="," close=")">
			#{item.gatewayPassword,jdbcType=VARCHAR}
		</foreach>
	</delete>

 上面红色"item.gatewayPassword"写法是错误滴,有时候我们写着写着就就与混还以为传入的是一个对象,当我们定义传入的 List 集合中是 String,Integer等时mapper.xml 中的实现:

	<delete id="delBatchPasswor" parameterType="java.util.List">
		delete from t_gateway_password where gateway_password in
		<foreach collection="list" item="item" open="(" separator="," close=")">
			#{item,jdbcType=VARCHAR}
		</foreach>
	</delete>

 

 

第二种情况:

我们在 DAO 中定义方法

int batchInsert(List<GatewayBusinessAh> list);

 这里传入的对象是自定义的实体对象,一般是通过表自动生成,再看看在 mapper.xml 中的实现:

INSERT INTO t_gateway_business_ah (
	id,
	gateway_uuid,
	business_code,
	business_code_boss,
	business_name,
	parameter_list,
	business_status,
	area_code,
	bandwidth,
	create_time,
	business_type,
	gateway_password,
	adsl_password,
	adsl_account,
	order_no,
	update_time,
	fail_count
)
VALUES
        <foreach collection="list" index="index" item="item" separator=",">
 (
      #{item.id,jdbcType=VARCHAR},
      #{item.gatewayUuid,jdbcType=VARCHAR},
      #{item.businessCode,jdbcType=VARCHAR},
      #{item.businessCodeBoss,jdbcType=VARCHAR},
      #{item.businessName,jdbcType=VARCHAR},
      #{item.parameterList,jdbcType=VARCHAR},
      #{item.businessStatus,jdbcType=VARCHAR},
      #{item.areaCode,jdbcType=VARCHAR},
      #{item.bandwidth,jdbcType=INTEGER},
      #{item.createTime,jdbcType=INTEGER},
      #{item.businessType,jdbcType=VARCHAR},
      #{item.gatewayPassword,jdbcType=VARCHAR},
      #{item.adslPassword,jdbcType=VARCHAR},
      #{item.adslAccount,jdbcType=VARCHAR},
      #{item.orderNo,jdbcType=VARCHAR},
      #{item.updateTime,jdbcType=INTEGER},
      #{item.failCount,jdbcType=INTEGER}
)
        </foreach>
    </insert>

 上面的错我找了很久都没有找到问题,我找问题步骤如下:

(1)查看parameterType的类型是不是java.util.List类型,如果是的话,看foreach 的collection属性是不是list.

(2)看一下foreach里面的"属性"是否写错或有没有传递进来,这里说一下"属性"好比上面"orderNo"是你实体对象中无此属性,我在网上看到有的说是"值"为空,感觉有些歧义.

上面排出错误的步骤都试了,可是还是没有找出问题.最后我对应表查看了字段:

 字段中并没有"businessName"属性,因为是开发环境,所以这些问题是坑,不知道什么时候被删除了.

所以我们还要对应看foreach里面的"属性"是否表中字段对应得上.

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值