mybatis条件查询容易遇见的错误
2017-12-19 16:05
423 查看
在使用mybatis的条件查询时,一不小心就容易出现这个错误:
19-Dec-2017 16:04:38.742 严重 [http-nio-8090-exec-6] org.apache.catalina.core.StandardWrapperValve.invoke Servlet.service() for servlet [SpringMVC] in context with path [] threw exception [Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException:
nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'endoscopeType' in 'class java.lang.String'] with root cause
org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'endoscopeType' in 'class java.lang.String'
at org.apache.ibatis.reflection.Reflector.getGetInvoker(Reflector.java:380)
at org.apache.ibatis.reflection.MetaClass.getGetInvoker(MetaClass.java:170)
at org.apache.ibatis.reflection.wrapper.BeanWrapper.getBeanProperty(BeanWrapper.java:152)
at org.apache.ibatis.reflection.wrapper.BeanWrapper.get(BeanWrapper.java:48)
这是mapper.xml文件:
出错的原因是因为加上 <if> 标签时,endoscope属性没有包含在String endoscopeType中,现有两种解决方法:
1.将<if>标签去掉;
2.传入参数放在对象中传进来;
19-Dec-2017 16:04:38.742 严重 [http-nio-8090-exec-6] org.apache.catalina.core.StandardWrapperValve.invoke Servlet.service() for servlet [SpringMVC] in context with path [] threw exception [Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException:
nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'endoscopeType' in 'class java.lang.String'] with root cause
org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'endoscopeType' in 'class java.lang.String'
at org.apache.ibatis.reflection.Reflector.getGetInvoker(Reflector.java:380)
at org.apache.ibatis.reflection.MetaClass.getGetInvoker(MetaClass.java:170)
at org.apache.ibatis.reflection.wrapper.BeanWrapper.getBeanProperty(BeanWrapper.java:152)
at org.apache.ibatis.reflection.wrapper.BeanWrapper.get(BeanWrapper.java:48)
这是mapper.xml文件:
<select id="findByEndoscopeType" resultMap="BaseResultMap" parameterType="java.lang.String"> SELECT * FROM endoscope <where> <if test="endoscopeType != null"> endoscope_type = #{endoscopeType,jdbcType=VARCHAR} </if> </where> </select>
出错的原因是因为加上 <if> 标签时,endoscope属性没有包含在String endoscopeType中,现有两种解决方法:
1.将<if>标签去掉;
2.传入参数放在对象中传进来;
<select id="findByEndoscopeType" resultMap="BaseResultMap" parameterType="com.iel.endoscope.entity.Endoscope"> SELECT * FROM endoscope <where> <if test="endoscopeType != null"> endoscope_type = #{endoscopeType,jdbcType=VARCHAR} </if> </where> </select>
相关文章推荐
- mybatis查询符合条件的记录数时错误there is no getter for property named。。。
- 电脑设置区域不同而导致查询数据库带时间条件的错误
- Mybatis 递归子查询遇见的问题
- mybatis查询sql中in条件使用(foreach)
- 几种mybatis 模糊查询条件写法
- mybatis 根据条件查询
- 03_MyBatis基本查询,mapper文件的定义,测试代码的编写,resultMap配置返回值,sql片段配置,select标签标签中的内容介绍,配置使用二级缓存,使用别名的数据类型,条件查询ma
- mybatis 多条件查询
- mybatis多条件的模糊查询解决方案
- mybatis拼接条件查询
- Mybatis中查询条件和返回的结果Map封装
- 关于Mybatis中的条件查询。createCriteria example里面的条件
- mybatis中传入一个List或Map集合作为查询条件的参数
- mybatis 的条件查询的三个方法实现
- 我的错误之mybatis查询
- Mybatis动态SQL 条件查询,批量删除
- Mybatis的条件分页查询
- mybatis使用in语句作为查询条件
- Mybatis 多条件动态查询
- Mybatis中查询条件和返回的结果Map封装