• SSM - Springboot - MyBatis-Plus 全栈体系(十七)


    第三章 MyBatis

    五、MyBatis 高级扩展

    1. mapper 批量映射优化

    1.1 需求
    • Mapper 配置文件很多时,在全局配置文件中一个一个注册太麻烦,希望有一个办法能够一劳永逸。
    1.2 配置方式
    • Mybatis 允许在指定 Mapper 映射文件时,只指定其所在的包:
    <mappers>
        <package name="com.alex.mapper"/>
    mappers>
    
    • 1
    • 2
    • 3
    • 此时这个包下的所有 Mapper 配置文件将被自动加载、注册,比较方便。
    1.3 资源创建要求
    • Mapper 接口和 Mapper 配置文件名称一致
      • Mapper 接口:EmployeeMapper.java
      • Mapper 配置文件:EmployeeMapper.xml
    • Mapper 配置文件放在 Mapper 接口所在的包内
      • 可以将 mapperxml 文件放在 mapper 接口所在的包!
      • 可以在 resources 下创建 mapper 接口包一致的文件夹结构存放 mapperxml 文件

    在这里插入图片描述
    在这里插入图片描述

    2. 插件和分页插件 PageHelper

    2.1 插件机制和 PageHelper 插件介绍
    • MyBatis 对插件进行了标准化的设计,并提供了一套可扩展的插件机制。插件可以在用于语句执行过程中进行拦截,并允许通过自定义处理程序来拦截和修改 SQL 语句、映射语句的结果等。
    • 具体来说,MyBatis 的插件机制包括以下三个组件:
    1. Interceptor(拦截器):定义一个拦截方法 intercept,该方法在执行 SQL 语句、执行查询、查询结果的映射时会被调用。
    2. Invocation(调用):实际上是对被拦截的方法的封装,封装了 Object targetMethod methodObject[] args 这三个字段。
    3. InterceptorChain(拦截器链):对所有的拦截器进行管理,包括将所有的 Interceptor 链接成一条链,并在执行 SQL 语句时按顺序调用。
    • 插件的开发非常简单,只需要实现 Interceptor 接口,并使用注解 @Intercepts 来标注需要拦截的对象和方法,然后在 MyBatis 的配置文件中添加插件即可。
    • PageHelper 是 MyBatis 中比较著名的分页插件,它提供了多种分页方式(例如 MySQL 和 Oracle 分页方式),支持多种数据库,并且使用非常简单。
    2.2 PageHelper 插件使用
    2.2.1 pom.xml 引入依赖
    <dependency>
        <groupId>com.github.pagehelpergroupId>
        <artifactId>pagehelperartifactId>
        <version>5.1.11version>
    dependency>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    2.2.2 mybatis-config.xml 配置分页插件
    • 在 MyBatis 的配置文件中添加 PageHelper 的插件:
    <plugins>
        <plugin interceptor="com.github.pagehelper.PageInterceptor">
            <property name="helperDialect" value="mysql"/>
        plugin>
    plugins>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 其中,com.github.pagehelper.PageInterceptor 是 PageHelper 插件的名称,dialect 属性用于指定数据库类型(支持多种数据库)
    2.2.3 页插件使用
    • 在查询方法中使用分页:
    @Test
    public void testTeacherRelationshipToMulti() {
    
        TeacherMapper teacherMapper = session.getMapper(TeacherMapper.class);
    
        PageHelper.startPage(1,2);
        // 查询Customer对象同时将关联的Order集合查询出来
        List<Teacher> allTeachers = teacherMapper.findAllTeachers();
    //
        PageInfo<Teacher> pageInfo = new PageInfo<>(allTeachers);
    
        System.out.println("pageInfo = " + pageInfo);
        long total = pageInfo.getTotal(); // 获取总记录数
        System.out.println("total = " + total);
        int pages = pageInfo.getPages();  // 获取总页数
        System.out.println("pages = " + pages);
        int pageNum = pageInfo.getPageNum(); // 获取当前页码
        System.out.println("pageNum = " + pageNum);
        int pageSize = pageInfo.getPageSize(); // 获取每页显示记录数
        System.out.println("pageSize = " + pageSize);
        List<Teacher> teachers = pageInfo.getList(); //获取查询页的数据集合
        System.out.println("teachers = " + teachers);
        teachers.forEach(System.out::println);
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    3. 逆向工程和 MyBatisX 插件

    3.1 ORM 思维介绍
    • ORM(Object-Relational Mapping,对象-关系映射)是一种将数据库和面向对象编程语言中的对象之间进行转换的技术。它将对象和关系数据库的概念进行映射,最后我们就可以通过方法调用进行数据库操作!!

    • 最终: 让我们可以使用面向对象思维进行数据库操作!!!

    • ORM 框架通常有半自动和全自动两种方式。

      • 半自动 ORM 通常需要程序员手动编写 SQL 语句或者配置文件,将实体类和数据表进行映射,还需要手动将查询的结果集转换成实体对象。
      • 全自动 ORM 则是将实体类和数据表进行自动映射,使用 API 进行数据库操作时,ORM 框架会自动执行 SQL 语句并将查询结果转换成实体对象,程序员无需再手动编写 SQL 语句和转换代码。
    • 下面是半自动和全自动 ORM 框架的区别:

    1. 映射方式:半自动 ORM 框架需要程序员手动指定实体类和数据表之间的映射关系,通常使用 XML 文件或注解方式来指定;全自动 ORM 框架则可以自动进行实体类和数据表的映射,无需手动干预。
    2. 查询方式:半自动 ORM 框架通常需要程序员手动编写 SQL 语句并将查询结果集转换成实体对象;全自动 ORM 框架可以自动组装 SQL 语句、执行查询操作,并将查询结果转换成实体对象。
    3. 性能:由于半自动 ORM 框架需要手动编写 SQL 语句,因此程序员必须对 SQL 语句和数据库的底层知识有一定的了解,才能编写高效的 SQL 语句;而全自动 ORM 框架通过自动优化生成的 SQL 语句来提高性能,程序员无需进行优化。
    4. 学习成本:半自动 ORM 框架需要程序员手动编写 SQL 语句和映射配置,要求程序员具备较高的数据库和 SQL 知识;全自动 ORM 框架可以自动生成 SQL 语句和映射配置,程序员无需了解过多的数据库和 SQL 知识。
    • 常见的半自动 ORM 框架包括 MyBatis 等;常见的全自动 ORM 框架包括 Hibernate、Spring Data JPA、MyBatis-Plus 等。
    3.2 逆向工程
    • MyBatis 的逆向工程是一种自动化生成持久层代码和映射文件的工具,它可以根据数据库表结构和设置的参数生成对应的实体类、Mapper.xml 文件、Mapper 接口等代码文件,简化了开发者手动生成的过程。逆向工程使开发者可以快速地构建起 DAO 层,并快速上手进行业务开发。
    • MyBatis 的逆向工程有两种方式:通过 MyBatis Generator 插件实现和通过 Maven 插件实现。无论是哪种方式,逆向工程一般需要指定一些配置参数,例如数据库连接 URL、用户名、密码、要生成的表名、生成的文件路径等等。
    • 总的来说,MyBatis 的逆向工程为程序员提供了一种方便快捷的方式,能够快速地生成持久层代码和映射文件,是半自动 ORM 思维像全自动发展的过程,提高程序员的开发效率。
    • 注意:逆向工程只能生成单表 crud 的操作,多表查询依然需要我们自己编写!
    3.3 逆向工程插件 MyBatisX 使用
    • MyBatisX 是一个 MyBatis 的代码生成插件,可以通过简单的配置和操作快速生成 MyBatis Mapper、pojo 类和 Mapper.xml 文件。下面是使用 MyBatisX 插件实现逆向工程的步骤:
    3.3.1 安装插件
    • 在 IntelliJ IDEA 中打开插件市场,搜索 MyBatisX 并安装。
    3.3.2 使用 IntelliJ IDEA 连接数据库
    3.3.2.1 连接数据库

    在这里插入图片描述

    3.3.2.2 填写信息

    在这里插入图片描述

    3.3.2.3 展示库表

    在这里插入图片描述

    3.3.2.4 逆向工程使用

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    3.3.3 查看生成结果

    在这里插入图片描述

    3.3.4 逆向工程案例使用
    • 正常使用即可,自动生成单表的 crud 方法!
    package com.alex.mapper;
    
    import com.alex.pojo.User;
    
    public interface UserMapper {
    
        int deleteByPrimaryKey(Long id);
    
        int insert(User record);
    
        int insertSelective(User record);
    
        User selectByPrimaryKey(Long id);
    
        int updateByPrimaryKeySelective(User record);
    
        int updateByPrimaryKey(User record);
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    六、MyBatis 总结

    核心点掌握
    mybatis 基础使用流程, 参数输入,#{} ${},参数输出
    mybatis 多表实体类设计,resultMap 多表结果映射
    mybatis 动态语句Mybatis 动态语句概念, where , if , foreach 标签
    mybatis 扩展Mapper 批量处理,分页插件,逆向工程
  • 相关阅读:
    科研试剂Cholesterol-PEG-Maleimide,CLS-PEG-MAL,胆固醇-聚乙二醇-马来酰亚胺
    大阳能充电新技术---Powerfoyle
    微服务微服务生态组件之Spring Cloud OpenFeign详解和源码分析
    ASP.NET Core - 选项系统之源码介绍
    C风格数组和std::array有什么区别
    服务器开发25:用libevent充当游戏服务器之间连接(libevent笔记及源码剖析)
    【打卡】21天学习挑战赛—RK3399平台开发入门到精通-day11
    深度学习,逻辑回归梯度下降向量化及一些编程基础
    SequoiaDB分布式数据库2022.7月刊
    API接口安全设计
  • 原文地址:https://blog.csdn.net/sgsgkxkx/article/details/133499782