文档章节

MyBatis3 单个参数使用if判断

壹城
 壹城
发布于 2016/09/28 14:03
字数 291
阅读 2551
收藏 2

MyBatis在使用单个参数进行if判断的时候,如果直接使用参数本身,则会报出:There is no getter for property named ... 的异常,比如

错误的代码:

<select id="findByFid" resultType="category" parameterType="integer">
    SELECT *
    FROM category
    <where>
        <if test="fid == null">fid IS NULL</if>
        <if test="fid != null">fid = #{fid}</if>
    </where>
</select>

这样写就会报出:Internal error : nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'fid' in 'class java.lang.Integer'的异常。

正确的方法是应该用“_parameter”来代替需要判断的参数:

<select id="findByFid" resultType="category" parameterType="integer">
    SELECT *
    FROM category
    <where>
        <if test="_parameter == null">fid IS NULL</if>
        <if test="_parameter != null">fid = #{fid}</if>
    </where>
</select>

当然,还有一种方法就是在Mapper接口中给定参数名,如:

List<Category> findByFid(Integer fid);

更改为:

List<Category> findByFid(@Param("fid") Integer fid);

这样xml中就可以使用最上面的那种写法,直接使用参数名做判断了,但是注意要去掉parameterType属性。

附送MyBatis官方中文手册:http://www.mybatis.org/mybatis-3/zh/index.html

完毕!

 

© 著作权归作者所有

壹城
粉丝 5
博文 2
码字总数 1423
作品 0
成都
程序员
私信 提问
加载中

评论(2)

壹城
壹城 博主

引用来自“失去的青春”的评论

参数做内容判断的时候 用== 还是用equals而且我这用equals时灵时不灵
用的是 == 和 != 的判断方式,可以参考官方文档的写法:http://www.mybatis.org/mybatis-3/zh/dynamic-sql.html
oldDriverSS
oldDriverSS
参数做内容判断的时候 用== 还是用equals而且我这用equals时灵时不灵
MyBatis3错误:Parameter 'id' not found. Available parameters are [arg2, arg1, arg0, param3, param1, param2]或者Parameter '0' not found. Available parameter

这个问题涉及到MyBatis3在使用select节点查询时传递多个参数的问题。问题分析如下: 1、如果是单个查询一般是这样配置: public List getUserArticles(int id); 2、如果使用了多个参数之后,...

easonjim
2017/06/20
0
0
mybatis配置文件解析错误解决方法

转:mybatis写mapper文件注意事项 mybatis3mappercdatamybatis3 null xml中某些特殊符号作为内容信息时需要做转义,否则会对文件的合法性和使用造成影响 < < > > & & ' ' " " 在mapper文件中写......

菠萝啊哈哈
2013/07/23
3K
2
mybatis-generator重新生成代码时的SQL映射文件覆盖

mybatis generator工具在使用的时候的时候,命令行输入:-overwrite 参数,表示生成的文件会覆盖原来的文件;但是在实际使用中发现,针对mybatis生成的SQL映射文件(xml文件)只能追加,不能...

alex
2014/04/08
23.3K
11
MyBatis3-动态SQL语句

MyBatis的动态SQL语句是基于OGNL表达式的。可以方便的在SQL语句中实现某些逻辑,总体说来MyBatis动态SQL语句主要有以下几类: 1、if语句(简单的条件判断)。 2、choose(when,otherwize),...

easonjim
2017/06/21
0
0
mybatis3中在mapper接口方法中如何使用多参

来源我的CSDN博客:http://blog.csdn.net/doctor_who2004/article/details/43027735 How do I use multiple parameters in a mapper? mybatis3中在mapper接口方法中如何使用多参 Java refle......

Beaver_
2015/06/05
607
0

没有更多内容

加载失败,请刷新页面

加载更多

Spring Security 自定义登录认证(二)

一、前言 本篇文章将讲述Spring Security自定义登录认证校验用户名、密码,自定义密码加密方式,以及在前后端分离的情况下认证失败或成功处理返回json格式数据 温馨小提示:Spring Security...

郑清
43分钟前
5
0
php yield关键字以及协程的实现

php的yield是在php5.5版本就出来了,而在初级php界却很少有人提起,我就说说个人对php yield的理解 Iterator接口 在php中,除了数组,对象可以被foreach遍历之外,还有另外一种特殊对象,也就是继承...

冻结not
56分钟前
4
0
servlet请求和响应的过程

本文转载于:专业的前端网站➥servlet请求和响应的过程 1.加载 Servlet类被加载到Java虚拟机中,并且实例化。在这个过程中,web容器(例如tomcat)会调用Servlet类的公开无参构造函数,产生一...

前端老手
57分钟前
4
0
golang 1.13 errors 包来了,不用写“err 气功波”代码

引 这篇是对 errors 包 的姿势挖掘 气功波错误代码 从 http.Get()返回的错误 判断 syscall.ECONNREFUSED 错误.以前要对 go 标准库 error 结构有点熟悉,才能写出下面的代码 func CmdErr(err ...

guonaihong
今天
32
0
喜玛拉雅已听书单

时间倒序排 书名 作者 状态 唐砖 孑与2 进行中 死灵之书(克苏鲁神话合集) 阿卜杜拉·阿尔哈萨德 进行中 赡养人类 刘慈欣 完结 赡养上帝 刘慈欣 完结 中国太阳 刘慈欣 完结 中国太阳 刘慈欣...

Alex_Java
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部