03 Lombok+AOP思想+注解进化SqlSession工具类03

Lombok

实体类中除了定义好的属性外,我们常常还要写set/get构造方法等,用Lombok可以用一条注解帮忙生成。

  • 一个@Data会同时包含
    @Getter/@Setter
    @ToString
    @EqualsAndHashCode
    @RequiredArgsConstructor

使用方法:需要同时添加Lombok插件和Lombok依赖。

在之前,因为每次获取一个sqlSession对象太麻烦,我们在02节封装了方法进SqlSessionUtil类中:

java 复制代码
package com.sunsplanter.mybatis.utils;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

public class SqlSessionUtil {
    //工具类的构造方法一般都是私有化的,目的是防止创建对象
    //工具类中的方法一般都是静态,目的是采用类名即可直接调用
    private static SqlSessionFactory sqlSessionFactory;

    /**
     * sqlSessionFactory与数据库是一对一的关系,因此类加载时初始化sqlSessionFactory对象
     * 而后长期存在,以后需要的时候仅仅是通过openSession获取一个会话对象
     */
    static {
        try {
            SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
            sqlSessionFactory = sqlSessionFactoryBuilder.build(Resources.getResourceAsStream("mybatis-config.xml"));
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /**
     * 每调用一次openSession()可获取一个新的会话,该会话支持自动提交。
     * @return 新的会话对象
     */
    public static SqlSession openSession() {
        return sqlSessionFactory.openSession(true);
    }
}

此后每个测试方法中代码得以简化为:

java 复制代码
    @Test
    public void testInsertCar(){
        SqlSession sqlSession = SqlSessionUtil.openSession();
        // 执行SQL
        int count = sqlSession.insert("insertCar");
        System.out.println("插入了几条记录:" + count);
        sqlSession.close();
    }

但这是比较老的方法。

我们可以利用AOP+注解进化,现在不再需要新建一个工具类,直接将抽象的方法放在测试类中,配合BeforeEach注解使用。

一个特别注意的点是,@BeforeEach仅在Junit5,注意引对依赖:

xml 复制代码
        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter-api</artifactId>
            <version>5.3.1</version>
        </dependency>

测试类中代码如下:

java 复制代码
    private SqlSession session;
   
    // junit会在每一个@Test方法前执行@BeforeEach方法
    @BeforeEach
    public void init() throws IOException {
        session = new SqlSessionFactoryBuilder()
                .build(
                        Resources.getResourceAsStream("mybatis-config.xml"))
                .openSession();
    }

    @Test
    public void testInsertCar() {
        SqlSession sqlSession = SqlSessionUtil.openSession();
        // 执行SQL
        int count = sqlSession.insert("insertCar");
        System.out.println("插入了几条记录:" + count);
        sqlSession.close();
    }
相关推荐
成富2 小时前
文本转SQL(Text-to-SQL),场景介绍与 Spring AI 实现
数据库·人工智能·sql·spring·oracle
鹿屿二向箔3 小时前
基于SSM(Spring + Spring MVC + MyBatis)框架的汽车租赁共享平台系统
spring·mvc·mybatis
豪宇刘3 小时前
SpringBoot+Shiro权限管理
java·spring boot·spring
一只爱打拳的程序猿4 小时前
【Spring】更加简单的将对象存入Spring中并使用
java·后端·spring
ajsbxi7 小时前
苍穹外卖学习记录
java·笔记·后端·学习·nginx·spring·servlet
鹿屿二向箔8 小时前
基于SSM(Spring + Spring MVC + MyBatis)框架的咖啡馆管理系统
spring·mvc·mybatis
NoneCoder9 小时前
Java企业级开发系列(1)
java·开发语言·spring·团队开发·开发
paopaokaka_luck15 小时前
【360】基于springboot的志愿服务管理系统
java·spring boot·后端·spring·毕业设计
Yaml417 小时前
Spring Boot 与 Vue 共筑二手书籍交易卓越平台
java·spring boot·后端·mysql·spring·vue·二手书籍
aloha_78917 小时前
从零记录搭建一个干净的mybatis环境
java·笔记·spring·spring cloud·maven·mybatis·springboot