mybatis对传入基本类型参数的判断方式有哪些
这篇文章主要介绍mybatis对传入基本类型参数的判断方式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
对传入基本类型参数的判断
mybatis的xml文件的sql语句中parameterType为基本类型,如:
<select id="getCustomer" parameterType="Integer" resultType="Customer"> select * from customer where <if test="id != null">id=#{id}</if><select>
会报错:There is no getter for property named 'id' in 'class java.lang.Integer'
这是因为Integer对象中没有id属性
解决办法
<select id="getCustomer" parameterType="Integer" resultType="Customer"> select * from Customer where <if test="_parameter != null">id=#{_parameter}</if><select>
即将接收参数的参数名改为_parameter,注意改成其他参数名没用。
传入基本类型参数时test判断报错
在使用mybatis的时候出现了这样的问题:
//Dao层的接口中的代码List<Map<String,Object>> getName(String username);
//对应的mapper中的代码<select id="getName" resultType="java.util.Map"> select name,client_id from table1 <where> <if test=" username!= null and username!='' "> and username= #{id} </if> </where> </select>
//报的错误
org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.ReflectionException:
There is no getter for property named 'username' in 'class java.lang.String'
分析
There is no getter for property named ‘username’ in ‘class java.lang.String’,这句话打大概意思是:在“class java.lang.String”中没有名为“username”的属性的getter方法。因为mybatis默认采用ONGL解析参数,所以会自动采用对象树的形式取string.num值,引起错误。
解决办法
if test中的id用_parameter替换,而实际的语句不需要修改and a.id =#{id},因为Mybatis当只传入一个参数时#{ } 中的内容没有要求。
在Mapper中给出入参设置名称,例:public … getName(@Param(“username”) String username);这样修改后我们前面的写法就不会报错了。
以上是“mybatis对传入基本类型参数的判断方式有哪些”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341