mybatis多表查询--单元测试抽取代码@Test配合工具类使用

单元测试类抽取成工具类(自己测试mybatis多表查询练习):
public class BaseMapperTest {
protected SqlSession sqlSession = null;
//此方法在测试方法执行之前,执行
@Before
public void before(){
//获取SqlSession对象
sqlSession = MybatisUtils.openSession(); //此方法必须线程内独自执行,不安全
}

//此方法在测试方法执行之后,执行
@After
public void after(){
    //关闭sqlSession
    MybatisUtils.close(sqlSession);
}

}

工具类:
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import java.io.IOException;
import java.io.InputStream;
//将mybatis测试代码的通用部分进行抽取,简化书写提高效率
public class MybatisUtils {
private static SqlSessionFactory sqlSessionFactory = null;
//在静态代码块中(1.加载核心配置文件 2.构建工厂对象)
static{
try {
//1.加载核心配置文件
InputStream is = Resources.getResourceAsStream(“SqlMapConfig.xml”);
//2.构建工厂对象
sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
} catch (IOException e) {
e.printStackTrace();
}
}
//提供获取sqlSession的静态方法
public static SqlSession openSession(){
return sqlSessionFactory.openSession();
}
//提供提交事务和释放资源方法
public static void close(SqlSession sqlSession){
//提交事务
sqlSession.commit();
//释放资源
sqlSession.close();
}
}

你可能感兴趣的:(笔记)