出现这个问题是因为Mybatis识别不了你的参数列表,所以才报这个错,如下:
org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter 'user_id' not found. Available parameters are [number, postId, page, param3, param1, param2]
解决过程如下:
1.对于mapper接口中,传入的参数有多个时必须使用@param
进行标识,查看了一下自己的代码,每个参数我都用@Param
注解标识了,可还是报这个错,见下图:
2.继续解决,有没有可能@Param
的包导错了,这个@Param
注解必须是mybatis
的包,查看一下导入的包,确定没导错,见下图:
3.那有可能是MySQL中你传入的参数跟你使用的值不一致,仔细检查了一遍sql语句,发现没啥毛病,见下图:传入的参数分别是#{postId},#{page},#{number},引用的时候也分别是这三个字段
4.定睛一看,报错信息说我的user_id
找不到 ,纵观整个sql语句中,只有中间这行有user_id
,于是我把这行去掉,运行成功,。。。。。。。。。。。。。。。。。。。。,心态崩了~~~
当时看这个用不上就随手注释了,结果卡我半天,真的是一失足成千古恨
还好最终还是解决了这个问题,再次记录一下,以防下次再出现这种问题