今天在执行数据插入操作的时候出现了一个错误,
console code
org.apache.ibatis.binding.BindingException:
Parameter '**'not found.Available parameters are [arg2,arg1,arg0,param2,param1,param0]...
也就是说我传入的参数找不到,这就让我十分奇怪。当我打开debug的时候,却发现执行service时,传入的参数确实有值的。
我猜想,是否是因为我的Service、ServiceImp、Dao、Mapper使用了不同名的参数。在两次的对照之后,排除了参数个数不一致及参数名不一致的猜想。
将问题在百度进行搜索,结果答案比较少, 并且大致是这两种意思:
- 在service里的参数前加上@param注解
- 在mapper.xml里面将参数改成#{0},#{1}
首先,我没有使用第一种方法,有代码洁癖的人应该和我一样,不会过多使用没有必要的注解。我选择了尝试了第二种方法,由于我传入了三个参数,所以代码写上:
xml code
<insert id="addUserInfo" parameterType="STRING">
insert into table_name (id,name,age) values(#{0},#{1},{2});
</insert>
在启动服务、发出请求之后,控制台依然报出了同样的错误,所以我也不知道为什么有人说这种方法有用。在寻找解决方法无果的情况下,我突然想到一个猜想,是不是参数比较多,mybatis无法识别我传递的参数具体是哪个呢?而且曾经听说mybatis会将传入的参数进行一次包装,会不会因为这个过程导致我的参数无法被拿到呢?
接着,我在model包下新建了一个User实体类。让他有id、name和age三个属性,生成对应的get和set方法。
而在控制器中,我将客户端传来的json数据转成User这个bean,然后修改Service、ServiceImp和Dao,让它们接收User这个实体,在mapper里面加上参数类型:
xml code
<insert id="addUserInfo" parameterType="com.springmvc.model.User">
insert into table_name (id,name,age) values(#{id},#{name},{age});
</insert>
重启服务,发出请求,正常响应请求。
初入java,有不正确的地方,欢迎指正!谢谢