MyBatis主要有几大核心类,了解并混个脸熟,方才称得上“入门MyBatis”。MyBatis主要的核心类包括:SqlSessionFactoryBuilder,SqlSessionFactory,SqlSession,Executor,StatementHandler,ResultSetHandler。

1、SqlSessionFactoryBuilder

每一个MyBatis的应用程序的入口是SqlSessionFactoryBuilder。它的作用是通过XML配置文件创建Configuration对象,然后通过build方法创建SqlSessionFactory对象。

public class App
{
    public static void main(String[] args) throws Exception
    {
        // 读取mybatis-config.xml文件
        InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");

        // 初始化mybatis,创建SqlSessionFactory类的实例
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

        // 创建Session实例
        SqlSession session = sqlSessionFactory.openSession();

        // 操作数据库方法一:获得xml映射文件中定义的操作语句
        Person p = session.selectOne("cn.mybatis.mydemo.mapper.PersonMapper.selectPersonById", 1);
        // 打印Peson对象
        System.out.println(p);

        // 操作数据库方法二:获得mapper接口的代理对象
        PersonMapper pm = session.getMapper(PersonMapper.class);
        // 直接调用接口的方法,查询id为1的Peson数据
        Person p2 = pm.selectPersonById(1);
        // 打印Peson对象
        System.out.println(p2);

        // 提交事务
        session.commit();
        // 关闭Session
        session.close();
    }
}

没有必要每次访问Mybatis就创建一次SqlSessionFactoryBuilder,通常的做法是创建一个全局的对象就可以了。示例程序如下:

private static SqlSessionFactoryBuilder sqlSessionFactoryBuilder;
private static SqlSessionFactory sqlSessionFactory;

private static void init() throws IOException 
{
    String resource = "mybatis-config.xml";
    Reader reader = Resources.getResourceAsReader(resource);
    sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
    sqlSessionFactory = sqlSessionFactoryBuilder.build(reader);
}

2、SqlSessionFactory

SqlSessionFactory的主要功能是创建SqlSession对象,和SqlSessionFactoryBuilder对象一样,没有必要每次访问Mybatis就创建一次SqlSessionFactory,通常的做法是创建一个全局的对象就可以了。

3、SqlSession

SqlSession类的主要功能是完成一次数据库的访问和结果的映射,它类似于一次会话概念,顾命名为:SqlSession。

SqlSession类似于JDBC里面的Connection,Connection不是线程安全的,SqlSession也不是线程安全的。由于不是线程安全的,所以SqlSession对象的作用域需限制方法内。

SqlSession的默认实现类是DefaultSqlSession,它有两个必须配置的属性:Configuration和Executor。mybatis-config.xml中的配置,最后会解析xml成Configuration这个类。SqlSession对数据库的操作都是通过Executor来完成的。

SqlSession有一个重要的方法getMapper,顾名思义,这个方式是用来获取Mapper映射器的。

更多关于SqlSession的介绍,请参考:《MyBatis核心对象SqlSession介绍》

4、Executor

Executor对象在创建Configuration对象的时候创建,并且缓存在Configuration对象里。

Executor对象的主要功能是调用StatementHandler访问数据库,并将查询结果存入缓存中(如果配置了缓存的话)。

5、StatementHandler

StatementHandler是真正访问数据库的地方,并调用ResultSetHandler处理查询结果。

6、ResultSetHandler

处理查询结果。

7、MyBatis核心类工作流程

mybatis-core-class.png

以上核心类,侧重于刻画数据库的交互过程,而在SQL封装以及动态SQL方面,还有两大核心类:MappedStatement和SqlSource。前者存储sql节点的属性,包括:id,resultMap,resultType,useCache等等;后者存储sql语句,实现动态sql的解析和处理。MyBatis核心类的整体介绍,请见下面小节。

8、MyBatis核心类层次&职责(详细版)

mybatis.png

SqlSession,作为MyBatis工作的主要顶层API,表示和数据库交互的会话,完成必要数据库增删改查功能

Executor,MyBatis执行器,是MyBatis调度的核心,负责SQL语句的生成和查询缓存的维护

StatementHandler,封装了JDBC Statement操作,负责对JDBC Statement的操作,如设置参数、将Statement结果集转换成List集合。

ParameterHandler,负责对用户传递的参数转换成JDBC Statement 所需要的参数

ResultSetHandler,负责将JDBC返回的ResultSet结果集对象转换成List类型的集合

TypeHandler,负责Java数据类型和JDBC数据类型之间的映射和转换

MappedStatement,MappedStatement维护了一条select|update|delete|insert节点的封装

SqlSource,负责根据用户传递的parameterObject,动态地生成SQL语句,将信息封装到BoundSql对象中,并返回
BoundSql,表示动态生成的SQL语句以及相应的参数信息

Configuration,MyBatis所有的配置信息都维持在Configuration对象之中

标签: none

添加新评论