@parame是mybatis提供的注解(org.apache.ibatis.annotations.Param)
记录在开发中用到一个问题:
1.情景一:
当我们的Mapper的接口是这样写的时候:
ApiCategoryInfo getInterfaceById(String id);
第一种:在mapper.xml文件中是这样写的话:
select * from api_category_info where id = #{id}
这样的查询是完全没有问题的
第二种:在Mapper.xml中这样写到的话
我们选择了有使用where标签的情况下,在我的接口不加@Parame注解的话,会报以下错误:
Caused by: org.apache.ibatis.reflection.ReflectionException: There is no getter for property named ‘id’ in ‘class java.lang.String’
这点的错误是我没呢的if标签在判断的时候报的错误,从报错信息可以知道我们的mybatis找不到名字为id的这个属性.
解决方法:在接口上添加@Parame标签
ApiCategoryInfo getInterfaceById(@Param(“id”) String id);这样子我们的mybatis就能通过标签知道了传进来的参数的名称是id,就可以判断这个属性了.