0
点赞
收藏
分享

微信扫一扫

Mybatis学习笔记,创建MybatisUtils工具类

吓死我了_1799 2022-01-24 阅读 62

一、为什么要创建工具类

在我使用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对象就可以了,大大提升了我们的开发效率,也增强了程序的可读性

举报

相关推荐

0 条评论