一、为什么要创建工具类
在我使用mybatis的时候,每用一次,都需要重复创建SqlSessionFactory对象和SqlSession对象,这大大降低了我们的开发效率,也让我们的代码看起来更复杂。
package org.example;
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 org.example.domain.Student;
import org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
public class MyTest {
@Test
//测试mybatis执行sql语句
public void testselectStudentbyid() throws IOException {
//定义mybatis主配置文件的位置
String config="mybatis.xml";
//读取主配置文件,使用mybatis框架中的Resources类
InputStream inputStream = Resources.getResourceAsStream(config);
//创建SqlSessionFactory,使用SqlSessionFactoryBuilder类
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(inputStream);
//获取SqlSession对象
SqlSession session=factory.openSession();
//指定要执行sql语句的id
String sqlId="org.example.dao.StudentDao"+"."+"selectStudentById";
//通过SqlSession的方法执行sql语句
Student stu=session.selectOne(sqlId);
System.out.println(stu);
//释放资源
session.close();
}
}
我们可以创建一个类,通过静态的方式让代码在开始执行的时候就自动加载出来SqlSession对象,这样就让我们的代码变的更简单,我们写起来也就更方便
二、创建工具类简化代码
首先创建一个工具类MyBatisUtil
然后利用静态代码块初始化SqlSessionFactory对象,并且在类里创建一个方法,用来获取SqlSession对象,代码如下
package org.example.Utils;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.jdbc.Null;
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;
/**
*
* 工具类,创建一个SqlSession对象
*/
public class MyBatisUtil {
// 创建SqlSessionFactory对象
private static SqlSessionFactory factory=null;
static {
//指定mybatis的主配置文件
String config="mybatis.xml";
try {
// 加载mybatis主配置文件
InputStream inputStream=Resources.getResourceAsStream(config);
// 实例化SqlSessionFactory对象
factory=new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
public static SqlSession getSqlSession(){
// 创建SqlSession对象
SqlSession session=null;
if (factory!=null){
// 如果工厂不为空,则开启SqlSession对象
session=factory.openSession();
}
return session;
}
}
然后创建一个测试类获取并使用这个工具类
package org.example;
import org.apache.ibatis.session.SqlSession;
import org.example.Utils.MyBatisUtil;
import org.example.demain.Student;
import org.junit.Test;
import java.util.List;
public class Mytest {
@Test
public void TestselectById(){
SqlSession sqlSession= MyBatisUtil.getSqlSession();
String sqlid="org.example.dao.StudentDao.selectById";
Student stu=sqlSession.selectOne(sqlid,1001);
System.out.println(stu);
sqlSession.close();
}
}
测试结果
这样我们就可以省去每次繁琐的获取SqlSessionFactory对象和SqlSession对象,使用的时候直接按照工厂模式使用工具类MyBatisUtil类创建SqlSession对象就可以了,大大提升了我们的开发效率,也增强了程序的可读性