Java持久层框架MyBatis全注解详解

栏目: IT技术 · 发布时间: 4年前

内容简介:MyBatis映射器的标记接口添加了@Mapper注解之后这个接口在编译时会生成相应的实现类需要注意的是:这个接口中不可以定义同名的方法,因为会生成相同的id
  • org.apache.ibatis.annotations

    org.apache.ibatis.annotations 包下有着 mybatis 所有的注解,让我们一文打尽!

    Java持久层框架MyBatis全注解详解

1 @Mapper

MyBatis映射器的标记接口

从mybatis3.4.0开始加入了@Mapper注解,目的就是为了不再写mapper映射文件

但是源码中并没有对于这个注解的详细解释

Java持久层框架MyBatis全注解详解

添加了@Mapper注解之后这个接口在编译时会生成相应的实现类

需要注意的是:这个接口中不可以定义同名的方法,因为会生成相同的id

  • 也就是说这个接口是不支持重载的

对于多个参数来说,每个参数之前都要加上@Param注解,

* 要不然会找不到对应的参数进而报错

2 @Param

mybatis中使用@param和不使用区别

使用@Param注解

当以下面的方式进行写 SQL 语句时:

@Select("select column from table where userid = #{userid} ")
public int selectColumn(int userid);

当你使用了使用@Param注解来声明参数时,如果使用 #{} 或 ${} 的方式都可以。

@Select("select column from table where userid = ${userid} ")
public int selectColumn(@Param("userid") int userid);

当你不使用@Param注解来声明参数时,必须使用使用 #{}方式。如果使用 ${} 的方式,会报错。

@Select("select column from table where userid = ${userid} ")
public int selectColumn(@Param("userid") int userid);

不使用@Param注解

不使用@Param注解时,参数只能有一个,并且是Javabean。在SQL语句里可以引用JavaBean的属性,而且只能引用JavaBean的属性。

// 这里id是user的属性

@Select("SELECT * from Table where id = ${id}")
Enchashment selectUserById(User user);

spring和mybatis中@param使用区别

spring中@param

/**
  * 查询指定用户和企业关联有没有配置角色
  * @param businessId  memberId
  * @return
  */
 int selectRoleCount(@Param("businessId") Integer businessId,@Param("memberId") Long memberId); 123456

mybatis中的param

/**
  * 查询指定用户和企业关联有没有配置角色
  * @param businessId memberId
  * @return
  */
 int selectRoleCount(@Param("businessId") Integer businessId,@Param("memberId") Long memberId); 123456

从表面上看,两种并没有区别,但是在xml文件中使用的时候是有区别的

Spring中的@param在xml需要如下这样引用变量

<select id="selectRoleCount" resultType="java.lang.Integer" >select 
    count(tbm.id)    from t_business_member_relation tbm    where tbm.business_id = #{0,jdbcType=INTEGER}
    and tbm.member_id = #{1,jdbcType=INTEGER}
    and tbm.role_business_id is not null
</select>

是根据参数的顺序来取值的,并且从0开始。而在mybatis @param在xml中则是如下这样引用变量的

<select id="selectRoleCount" resultType="java.lang.Integer" >    select 
    count(tbm.id)    from t_business_member_relation tbm    where tbm.business_id = #{businessId,jdbcType=INTEGER}
    and tbm.member_id = #{memberId,jdbcType=INTEGER}
    and tbm.role_business_id is not null
 </select>

是通过参数名来引用的

注:如果Mapper.java文件中引用的是Spring的

org.springframework.data.repository.query.Param;1

但是Mapper.xml中使用的是mybatis 的用法,那么就会如下的错误

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter ‘businessId’ not found. Available parameters are [1, 0, param1, param2]1


以上所述就是小编给大家介绍的《Java持久层框架MyBatis全注解详解》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Pro Git (Second Edition)

Pro Git (Second Edition)

Scott Chacon、Ben Straub / Apress / 2014-11-9 / USD 59.99

Scott Chacon is a cofounder and the CIO of GitHub and is also the maintainer of the Git homepage ( git-scm.com ) . Scott has presented at dozens of conferences around the world on Git, GitHub and the ......一起来看看 《Pro Git (Second Edition)》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试