传多个参数导致mybatis识别不出参数名
传多个参数导致mybatis识别不出参数名
Clover286 发表于11个月前
传多个参数导致mybatis识别不出参数名
  • 发表于 11个月前
  • 阅读 294
  • 收藏 1
  • 点赞 0
  • 评论 0

标题:腾讯云 新注册用户域名抢购1元起>>>   

下面这个dao层的接口,里面传了3个参数进去,

public int insertOrderMapProducts(int orderId,int productsId,int amount);

下面是mybatis的map xml配置

<insert id="insertOrderMapProducts" parameterType="int">
		INSERT
		INTO
		shop_orderandproducts(orderId,productsId,amount)
		VALUES
		(#{orderId},#{productsId},#{amount});
	</insert>

以上情况会报错:

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter 'orderId' not found. Available parameters are [0, 1, 2, param3, param1, param2]

重点是:

Parameter 'orderId' not found

意思是mybatis没找到orderId这个参数,为什么呢?怎么办?

原因:Java是用arg0,arg1代表参数的,所以mybatis无法识别这3个参数名

解决方案:

方法1:把这个3个参数封装到一个entity实体类中,直接把该实体类作为参数传进去

方法2:加入mybatis注解@Param,告诉mybatis参数的名字,如下:

public int insertOrderMapProducts(@Param("orderId") int orderId, @Param("productsId") int productsId,
			@Param("amount") int amount);

 

共有 人打赏支持
粉丝 8
博文 168
码字总数 61282
×
Clover286
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: