02封装获取sqlSession会话对象的工具类

编写MyBatis工具类SqlSessionUtil
为什么?每一个类透过MyBatis连接数据库都要使用以下代码连接数据库,而我们可能有多个类需要连接。

  SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
            //MyBatis包含了一个Resources类,用Resources类调方法,默认从类的根目录下开始找,因此如果mybatis-config.xml就放在Resources目录下,直接写名字就可以
            InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");//mybatis核心配置文件的路径

            SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(inputStream);

            sqlSession = sqlSessionFactory.openSession();

现在我们把这些代码封装起来。
项目结构如图
02封装获取sqlSession会话对象的工具类_第1张图片

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);
    }
}
package com.sunsplanter.mybatis.test;

import com.sunsplanter.mybatis.utils.SqlSessionUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

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

你可能感兴趣的:(Mybatis,mybatis)