说明:java
最近在使用动态SQL中的<if>标签合并接口和SQL的过程遇到了一些坑,放在这记录一下app
首先咱们有下面这样一个mapper接口(根据status变量来选择不一样的SQL):cdn
问题:There is no getter for property named 'xxxx' in 'class java.lang.String'xml
缘由:Mybatis默认采用OGNL解析参数,因此会自动采用对象树的形式取 string.xxx 值,若是对象中没有方法定义,则会抛异常报错。对象
解决方案1:在Mapper接口使用@Param注解标记参数名blog
而后能够这么写:接口
解决方案2:把mapper.xml使用的 变量名(如本例的status)修改成 _parameter 便可get