Mybatis基于注解与XML开发使用流程

 更新时间:2023年07月28日 10:55:48   作者:学废Java  
MyBatis是Java的持久化框架,目的是为了使操作数据库更加方便、灵活、高效,可以通过Java注解和XML文件来映射Java对象和SQL语句,提供了非常灵活的SQL编写方式和动态SQL语句的创建方式,这篇文章主要介绍了Mybatis基于注解与XML开发,需要的朋友可以参考下

1 关于SpringBoot

SpringBoot是一个基于Spring框架的快速开发的脚手架,它能够帮助我们开发者快速搭建项目环境,并提供了一些建议的配置方式,降低了开发者程序的开发和部署难度。

2 关于MyBatis

2.1 MyBatis概述

MyBatis是Java的持久化框架,目的是为了使操作数据库更加方便、灵活、高效。可以通过Java注解和XML文件来映射Java对象和SQL语句,提供了非常灵活的SQL编写方式和动态SQL语句的创建方式,可以与Spring框架结合使用。

2.2 MyBatis核心思想

将Java对象和数据库操作分离,通过注解和XML映射文件映射到数据库的字段上,并提供相应的API来操作数据库。可以自动将SQL语句转为JDBC代码,并根据指定的返回值类型生成对应的结果提供给开发者使用。

2.3 MyBatis使用流程

1.配置MyBatis环境
在pom.xml中添加相关依赖:MyBatis Framework 和 MySQL Driver
2.配置文件中配置数据库的连接信息(application.properties)

     spring.datasource.url=jdbc:mysql://localhost:3306/blog?characterEncoding=utf8&serverTimezone=Asia/Shanghai
      spring.datasource.username=root
      spring.datasource.password=root

3.定义pojo类,和数据表做好映射关系

4.编写Dao层接口,在接口中定义操作数据库的方法,在注解或者XML文件中实现具体的SQL语句。

      @Mapper
      public interface UserMapper{
          @Insert("INSERT INTO user VALUES(NULL,#{username})")
          int insert(User user);
      }

5.使用

       // 1.自动装配
       @Autowired
       private UserMapper userMapper
       // 2.调用方法
       userMpper.insert(...)

3 MyBatis配置SQL方式

3.1 基于注解方式

3.1.1 说明

基于注解方式省去了配置XML文件的编写工作,并且可以很方便的完成一些 简单的 CRUD操作,但是对于一些复杂的SQL语句使用起来会很冗余。

3.1.2 使用流程

  • (maven工程)在pom.xml中添加MyBatis和MySQL相关的依赖
  • 在配置文件中(application.properties)配置数据库的连接信息
  • 创建实体类,和数据库中的表做好对应关系
  • 配置Mapper接口,在接口中添加@Mapper注解,告诉底层为此接口创建实现类,在实现类中定义数据访问的逻辑,执行与数据库的会话
  • 在接口中定义方法,在方法上使用注解标注SQL语句的类型,可以使用的注解有:@Insert、@Dlelete、@Update、@Select
  • 如果SQL语句中涉及到多个参数,可以使用@Param注解给每个参数取名。
  • 自动装配并在应用程序中使用即可
     @Autowired
      private XxxMapper xxxMapper;
      xxxMapper.接口中的方法(参数...);

3.1.3 常用注解

  • @Insert(“SQL”)
  • @Dlelete(“SQL”)
  • @Update(“SQL”)
  • @Select(“SQL”)

3.2 基于XML方式

3.2.1 相比注解优势

  • 更好的可读性
  • XML文件具有良好的结构和语义,可以使JAVA代码和SQL语句彻底分离,便于管理和优化。注解配置SQL语句可能使JAVA代码变的冗长。
  • 更好的复用性
  • 将SQL语句写入XML文件中,通过 和标签 将重复的SQL抽取并引用,从而提高了SQL语句的复用性。
  • 更好的支持动态SQL
  • 动态SQL语句是根据运行时的参数来生成的SQL,复杂性较高,使用XML文件更加方便。

3.2.2 使用流程

  • 添加依赖:pom.xml
  • 配置数据源:application.propertis
  • 配置xml文件的扫描路径:application.properties
  • 创建实体类,做好和数据表的对应关系
  • 定义接口,添加@Mapper注解,并定义接口中的方法
  • 创建xml文件,使用标签配置SQL
  • 装配使用
      @Autowired
      private XxxMapper xxxMapper;
    xxxMapper.接口方法(参数...);

3.2.3 常用标签

  • insert标签
  • delelte标签
  • update标签
  • select标签
    使用select标签需要指定 resultType 的属性值
  • foreache标签:用于动态删除
      <delete id="xxx">
      	DELETE FROM xxx WHERE id in(
          	<foreache collection="对象类型" item="变量名" separator="分隔符">
          		#{变量名}
          	</foreache>
          )
      </delete>

set标签和if标签:用于动态修改

      <update id="xxx">
      	UPDATE xxx 
          <set>
          	<if test="属性名!=null">字段名=#{属性名},</if>
              <if test="属性名!=null">字段名=#{属性名},</if>
              <if test="属性名!=null">字段名=#{属性名}</if>
          </set>
      </update>

sql标签和include标签:用于SQL语句的复用

      <!--1.重复SQL抽取-->
      <sql id="selectSql">
          SELECT * FROM xxx
      </sql>
      <select id="xxx" resultType="xxx">
          <include refid="selectSql"></include>
      </select>
      <select id="yyy" resultType="yyy">
          <include refid="selectSql"></include> WHERE id&gt;5
      </select>

到此这篇关于Mybatis基于注解与XML开发的文章就介绍到这了,更多相关Mybatis注解XML开发内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java 正确终止线程的方法

    Java 正确终止线程的方法

    这篇文章主要介绍了Java 正确终止线程的方法,帮助大家更好的理解和学习java 多线程的相关知识,感兴趣的朋友可以了解下
    2020-12-12
  • Spring注解之@Value详解

    Spring注解之@Value详解

    这篇文章主要介绍了Spring注解之@Value详解,@Value可以修饰属性、方法、参数、注释类型,编译器会将 @Value注解的信息保留在 .class 文件中,并且能被虚拟机读取,需要的朋友可以参考下
    2024-01-01
  • Java中API的使用方法详情

    Java中API的使用方法详情

    这篇文章主要介绍了Java中API的使用方法详情,指的就是 JDK 中提供的各种功能的 Java类,这些类将底层的实现封装了起来,我们不需要关心这些类是如何实现的,只需要学习这些类如何使用即可,我们可以通过帮助文档来学习这些API如何使用,需要的朋友可以参考下
    2022-04-04
  • spring boot admin 搭建详解

    spring boot admin 搭建详解

    本篇文章主要介绍了spring boot admin 搭建详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • Spring Boot处理全局统一异常的两种方法与区别

    Spring Boot处理全局统一异常的两种方法与区别

    这篇文章主要给大家介绍了关于Spring Boot处理全局统一异常的两种方法与区别,文中通过示例代码介绍的非常详细,对大家学习或者使用Spring Boot具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-06-06
  • Jackson库进行JSON 序列化时遇到了无限递归(Infinite Recursion)的问题及解决方案

    Jackson库进行JSON 序列化时遇到了无限递归(Infinite Recursion)的问题及解决方案

    使用Jackson库进行JSON序列化时遇到了无限递归(Infinite Recursion)问题,这是因为两个实体类ComPointQuotaEntity和 ComPointEntity之间存在双向关联point和pointQuota相互引用,本文给大家介绍解决方案,感兴趣的朋友一起看看吧
    2025-03-03
  • Java设计模式中观察者模式详解

    Java设计模式中观察者模式详解

    观察者模式是极其重要的一个设计模式,也是我几年开发过程中使用最多的设计模式,本文首先概述观察者模式的基本概念和Demo实现,接着是观察者模式在Java和Spring中的应用,最后是对观察者模式的应用场景和优缺点进行总结
    2022-11-11
  • 通过Spring Boot配置动态数据源访问多个数据库的实现代码

    通过Spring Boot配置动态数据源访问多个数据库的实现代码

    这篇文章主要介绍了通过Spring Boot配置动态数据源访问多个数据库的实现代码,需要的朋友可以参考下
    2018-03-03
  • Spring原生Rpc六种的正确打开方式实现示例

    Spring原生Rpc六种的正确打开方式实现示例

    这篇文章主要为大家展示了Spring原生Rpc六种的正确打开方式实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助祝大家多多进步早日升职加薪
    2022-02-02
  • 使用MDC快速查询应用接口全部执行日志

    使用MDC快速查询应用接口全部执行日志

    这篇文章主要为大家介绍了使用MDC快速查询应用接口全部执行日志的方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01

最新评论