iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Mybatis常见注解有哪些
  • 688
分享到

Mybatis常见注解有哪些

2023-06-07 13:06:49 688人浏览 八月长安
摘要

本篇内容主要讲解“mybatis常见注解有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Mybatis常见注解有哪些”吧!当下,注解非常流行,以前很长篇的代码,现在基本上一个注解就能搞定。那

本篇内容主要讲解“mybatis常见注解有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Mybatis常见注解有哪些”吧!

当下,注解非常流行,以前很长篇的代码,现在基本上一个注解就能搞定。

那,在Mybatis中又有哪些注解呢?

Mybatis常见注解有哪些

Mybatis中的注解基本上都在org.apache.ibatis.annotations目录下:

Mybatis常见注解有哪些 

@MapperScan

该注解存在着争议,但不可否认的是这个注解确实是Mybatis的注解,是为了集成spring而写的注解。该注解主要是扫描某个包目录下的Mapper,将Mapper接口类交给Spring进行管理。

org.mybatis.spring.annotation.MapperScan

使用方式

@SpringBootApplication@MapperScan("com.tian.mybatis.mapper")public class Application {}

其实,从名字上就能看出,是用来扫描的Mapper的。

扫描包路径可以是一个或者多个,也可以在路径中可以使用 * 作为通配符对包名进行匹配 。

@SpringBootApplication@MapperScan("com.tian.*.mapper")public class Application {}@SpringBootApplication@MapperScan({"com.tian.mybatis.mapper","com.tian.mybatis.mapper1"})public class Application {}

灵活度相当高,这样在实际上项目中,我们就可以指定扫描想要被扫描的包路径。

@Mapper

该注解目的就是为了不再写mapper映射文件 (UserMapper.xml)。可以大大的简化编写xml的繁琐。该注解是由Mybatis框架中定义的一个描述数据层接口的注解,注解往往起到的都是一个描述性作用,用于告诉Spring框架此接口的实现类由Mybatis负责创建,并将其实现类对象存储到spring容器中。

使用方式

@Mapperpublic interface UserMapper {   User selectById(Integer id); }

@Insert

插入记录的时候主键如何生成?对此基本上有三种方案,分别是:手动指定(应用层)、自增主键(数据层单表)、选择主键(数据层多表)。

对应xml文件中的<insert>标签。

在应用层手动指定主键

手动指定的方式不把主键区别看待,插入之前在应用层生成对象的时候就会给主键一个值,插入的时候与普通字段没啥区别。

@Insert("INSERT INTO t_user (id, username, passwd) VALUES (#{id}, #{username}, #{passwd})")int addUserAssignKey(User user);

在上面的这个例子中,mybatis并不知道到底哪个字段是主键,id虽然是主键字段,但并没有被区别对待。

「注意」

#{username}这种写法,是把User作为了当前上下文,这样访问User的属性的时候直接写属性名字就可以了。

表自增主键

自增主键对应着XML配置中的主键回填,一个简单的例子:

@Options(useGeneratedKeys = true, keyProperty = "id")@Insert("INSERT INTO t_user (username, passwd) VALUES (#{username}, #{passwd})")int addUserGeneratedKey(User user);

使用Option来对应着XML设置的select标签的属性,userGeneratordKeys表示要使用自增主键,keyProperty用来指定主键字段的字段名。自增主键会使用数据库底层的自增特性。

选择主键

选择主键从数据层生成一个值,并用这个值作为主键的值。

@Insert("INSERT INTO t_user (username, passwd) VALUES (#{username}, #{passwd})")@SelecTKEy(statement = "SELECT UNIX_TIMESTAMP(NOW())", keyColumn = "id", keyProperty = "id", resultType = Long.class, before = true)int addUserSelectKey(User user);

@Delete

删除的时候只要把语句条件神马的写在@Delete注解的value里就好了,返回一个int类型是被成功删除的记录数。对应xml文件中的<delete>标签。

@Delete("DELETE FROM t_user WHERE id=#{id}")int delete(Long id);

@Update

修改的时候和删除一样只要把sql语句写在@Update的value中就好了,返回一个int类型表示被修改的记录行数。

对应xml文件中的<update>标签。

@Update("UPDATE t_user SET username=#{username}, passwd=#{passwd} WHERE id=#{id}")int update(User user);

@Select

查询的时候稍稍有些复杂,因为查询会涉及到如何将查出来的字段设置到对象上,对应xml文件中的<select>标签。

通常有那么三种办法:

在SQL语句中手动指定别名来匹配

在写SQL语句的时候,手动为每一个字段指定一个别名来跟对象的属性做匹配,适用于表字段名与对象属性名差异很大没有规律并且表字段不多的情况。

@Select("SELECT id, username, passwd, birth_day AS birthDay FROM t_user WHERE id=#{id}")User loadByIdHandAlias(Long id);

使用mybatis的自动下划线驼峰转换

mybatis有一个选项叫mapUnderscoreToCamelCase,当表中的字段名与对象的属性名相同只是下划线和驼峰写法的差异时适用。

配置了mapUnderscoreToCamelCase之后mybatis在将ResultSet查出的数据设置到对象的时候会尝试先将下划线转换为驼峰然后前面拼接set去设置属性。

开启转换:

Mybatis常见注解有哪些

然后查询

@Select("SELECT * FROM t_user WHERE id=#{id}")User loadByIdAutoAlias(Long id);

查看打印的结果,birth_day属性填充到了对象中:

Mybatis常见注解有哪些 

使用ResultMap

对于表的字段名和对象的属性名没有太大相同点并且表中的字段挺多的情况下,应该使用ResultMap做适配。

@Results(id = "userMap", value = {    //可以使用这种方式来处理字段名和数据库表字段名不一致的情况    @Result(id=true, column = "id", property = "id"),    @Result(column = "username", property = "username"),    @Result(column = "passwd", property = "passwd"),    @Result(column = "birth_day", property = "birthDay")})@Select("SELECT * FROM t_user WHERE id=#{id}")User loadByIdResultMap(Long id);

@Results对应着XML中的ResultMap,同时可以为其指定一个id,其它地方可以使用这个id来引用它,比如要引用上面的这个Results:

@ResultMap("userMap")@Select("SELECT * FROM t_user WHERE id=#{id}")User loadByIdResultMapReference(Long id);

使用@ResultMap来引用一个已经存在的ResultMap,这个ResultMap可以是在Java中使用@Results注解定义的,也可以是在XML中使用resultMap标签定义的。

增删改查注解总结

Mybatis常见注解有哪些 

其他注解

@Results:结果映射的列表, 包含了一个特别结果列如何被映射到属性或字段的详情。属 性:value, id。value 属性是 Result 注解的数组。对应xml中的<resultMap> 标签。

@Result:在列和属性或字段之间的单独结果映 射。属 性:id,column, property, javaType ,jdbcType ,type Handler, one,many。id 属性是一个布尔值,表 示了应该被用于比较(和在 XML 映射 中的相似)的属性。one 属性是单 独 的 联 系, 和 <association> 相 似 , 而 many 属 性 是 对 集 合 而 言 的 , 和 <collection>相似。它们这样命名是为了 避免名称冲突。类似于<resultMap>的子标签 <result>``<id>

@One:复杂类型的单独属性值映射。属性: select,已映射语句(也就是映射器方 法)的完全限定名,它可以加载合适类 型的实例。注意:联合映射在注解 api 中是不支持的。这是因为 Java 注解的 限制,不允许循环引用。类似于<association>标签。

@Many:与@One类似,一对多的关系,类似于<collection>

@Param :参数标签,我们在Mapper的方法签名上标注的参数,我们可以指定参数名称,然后在注解中或者xml中的SQL里就可以使用我们自定义的参数名称。

@SelectKey :获取最新插入id。

@CacheNamespace :为给定的命名空间 (比如类) 配置缓存。对应xml中的<cache>

@CacheNamespaceRef :参照另外一个命名空间的缓存来使用。属性:value,应该是一个名空间的字 符串值(也就是类的完全限定名) 。对应xml中的<cacheRef>标签。

@ConstructorArgs :收集一组结果传递给一个劫夺对象的 构造方法。属性:value,是形式参数 的数组。

@Arg :单 独 的 构 造 方 法 参 数 , 是 ConstructorArgs 集合的一部分。属性: id,column,javaType,typeHandler。id 属性是布尔值, 来标识用于比较的属 性,和XML 元素相似。对应xml中的<arg>标签。

@Case :单独实例的值和它对应的映射。属性: value,type,results。Results 属性是结 果数组,因此这个注解和实际的 ResultMap 很相似,由下面的 Results 注解指定。对应xml中标签<case>

Mybatis常用注解对应的目标和标签

Mybatis常见注解有哪些 

总结

mybatis最初配置信息是基于 XML ,映射语句(SQL)也是定义在 XML 中的。而到了 MyBatis 3提供了新的基于注解的配置。mybatis提供的注解有很多,笔者进行了分类:

  • 「增删改查:」@Insert、@Update、@Delete、@Select、@MapKey、@Options、@SelelctKey、@Param、@InsertProvider、@UpdateProvider、@DeleteProvider、@SelectProvider

  • 「结果集映射:」@Results、@Result、@ResultMap、@ResultType、@ConstructorArgs、@Arg、@One、@Many、@TypeDiscriminator、@Case

  • 「缓存:」@CacheNamespace、@Property、@CacheNamespaceRef、@Flush

绝大部分注解,在xml映射文件中都有元素与之对应,但是不是所有。此外在mybatis-spring中提供了@Mapper注解和@MapperScan注解,用于和spring进行整合。

到此,相信大家对“Mybatis常见注解有哪些”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: Mybatis常见注解有哪些

本文链接: https://www.lsjlt.com/news/249590.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mybatis常见注解有哪些
    本篇内容主要讲解“Mybatis常见注解有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Mybatis常见注解有哪些”吧!当下,注解非常流行,以前很长篇的代码,现在基本上一个注解就能搞定。那...
    99+
    2023-06-07
  • mybatis常用注解有哪些
    MyBatis常用的注解有以下几种:1. @Mapper:用于标识该接口是一个MyBatis的Mapper接口。2. @Select...
    99+
    2023-09-16
    mybatis
  • MyBatis常见面试题有哪些
    这篇文章给大家分享的是有关MyBatis常见面试题有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。  1、什么是Mybatis  Mybatis是一个半ORM(对象关系映射)框架,它内部封装了JDBC,开发时...
    99+
    2023-06-04
  • 常见AdobeFlex误解有哪些
    这篇文章主要介绍常见AdobeFlex误解有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!对AdobeFlex的误解在Qcon上,Adobe的JamesWard和InfoQ.com一起分享了他推广传播Flex应用...
    99+
    2023-06-17
  • Mybatis常见入参方式(Map、注解、JavaBean)
    目录 1、使用Map传参; 2、使用注解传参; 3、使用JavaBean传参; 4、Mybatis使用#{}和${}注入参数的区别; Mybatis给映射器传递多个参数分为以下三种方法。 1、使用Map传参; select u...
    99+
    2023-09-14
    mybatis java mysql
  • 常见的AdobeFlex误解有哪些
    小编给大家分享一下常见的AdobeFlex误解有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!常见AdobeFlex误解在Qcon上,Adobe的JamesW...
    99+
    2023-06-17
  • java常用注解有哪些
    Java常用注解包括:1. @Override:用于标注方法覆盖父类方法。2. @Deprecated:用于标注不推荐使用的方法或类...
    99+
    2023-05-29
    java常用注解 java
  • hibernate常用注解有哪些
    Hibernate常用注解有:1. @Entity:指示该类是一个实体类,对应数据库中的一个表。2. @Table:指定实体类对应的...
    99+
    2023-09-16
    hibernate
  • SpringBoot常用注解有哪些
    这篇文章给大家分享的是有关SpringBoot常用注解有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。  SpringBoot注解  @SpringBootApplication:开启Spring Boot自...
    99+
    2023-06-02
  • Java常见异常有哪些
    这篇文章主要介绍Java常见异常有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、概述异常指不期而至的各种状况,它在程序运行的过程中发生。作为开发者,我们都希望自己写的代码 永远都不会出现 bug,然而现实告诉...
    99+
    2023-06-15
  • IE6有哪些常见CSS解析Bug
    这篇文章主要讲解了“IE6有哪些常见CSS解析Bug”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“IE6有哪些常见CSS解析Bug”吧!    1.默认高度(IE6)&n...
    99+
    2023-06-05
  • SpringMVC常用的注解有哪些
    SpringMVC常用的注解有:1. @Controller:用于标识一个类是SpringMVC的控制器。2. @RequestMa...
    99+
    2023-09-13
    SpringMVC
  • Android常见bug有哪些
    这篇文章给大家分享的是有关Android常见bug有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、关于使用OkHttp运行时出现的错误报错如下:Static interface met...
    99+
    2023-06-14
  • SpringMVC中有哪些常用注解
    SpringMVC中有哪些常用注解?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。MVC简介MVC 全名是 Model View Controller,是模型(model)-视图...
    99+
    2023-06-15
  • 常用的Springboot注解有哪些
    常用的Spring Boot注解有以下几种:1. @SpringBootApplication:该注解用于标记启动类,表示该类是Sp...
    99+
    2023-10-11
    springboot
  • 常见的Java异常有哪些
    本篇文章为大家展示了常见的Java异常有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。异常是 Java 程序中经常遇到的问题,我想每一个 Java 程序员都讨厌异常,一 个异常就是一个 BUG,...
    99+
    2023-06-16
  • Python常见的异常有哪些
    这篇文章主要介绍“Python常见的异常有哪些”,在日常操作中,相信很多人在Python常见的异常有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python常见的异常有哪些”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-16
  • JAVA语言的常见误解有哪些
    这篇文章主要介绍JAVA语言的常见误解有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.JAVA是HTML的扩充JAVA是一个编程语言,HTML是一个页面描述语言。除了新版本HTML可以在WEB页中插入JA-V...
    99+
    2023-06-03
  • 有哪些IE6常见bug解决方法
    这篇文章主要讲解了“有哪些IE6常见bug解决方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“有哪些IE6常见bug解决方法”吧! ...
    99+
    2024-04-02
  • SpringBoot中常用的注解有哪些
    这篇文章主要介绍了SpringBoot中常用的注解有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、@SpringBootApplication此注解是Spring B...
    99+
    2023-06-21
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作