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();
}