五、SqlSessionFactory 和 SqlSession的介绍(补充)
5.1、SqlSessionFactory
? ????SqlSessionFactory 是一个重量级组件,线程安全的,一般情况下一个数据库对应一个 SqlSessionFactory 对象,所以一般情况下一个应用仅需要一 个SqlSessionFactory 对象;通过 SqlSessionFactory 生成 SqlSession 对象。
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(input);
? 如果要使用其他的数据库环境则在创建工厂对象时需指定环境:
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(input,test);
5.2、SqlSession
? ????SqlSession 是一个轻量级组件,非线程安全的,该对象通过SqlSessionFactory 对象来获得,SqlSession 对象我们可以看成一个数据库连接对象。该对象中封装了大量操作数据库的方法;由于 SqlSession 是非线程安全的,每次使用时要获得一个 SqlSession 对象,使用结束后关闭该对象;
? ????SqlSessionFactory 有 8 个方法创建 SqlSession 实例。通常来说,当你选择其中一个方 法时,你需要考虑以下几点:
-
事务处理:你希望在 session 作用域中使用事务作用域,还是使用自动提交 (auto-commit)?(对很多数据库和/或 JDBC 驱动来说,等同于关闭事务支持) -
数据库连接:你希望 MyBatis 帮你从已配置的数据源获取连接,还是使用自己提供的连接? -
语句执行:你希望 MyBatis 复用 PreparedStatement 和/或批量更新语句(包括插入语句和删除语句)吗?
SqlSession openSession()
openSession(boolean autoCommit)
openSession(Connection connection)
SqlSession openSession(ExecutorType execType)
默认的 openSession() 方法没有参数,它会创建具备如下特性的 SqlSession:
-
事务作用域将会开启(也就是不自动提交)。 -
将由当前环境配置的 DataSource 实例中获取 Connection 对象。 -
事务隔离级别将会使用驱动或数据源的默认设置。 -
预处理语句不会被复用,也不会批量处理更新。
所以我们一般使用 openSession(ExecutorType.BATCH)这个方法获取 SqlSession 对象。
ExecutorType这个枚举类型定义了三个值:
-
ExecutorType.SIMPLE:该类型的执行器没有特别的行为。它为每个语句的执行创建一个新的预处理语句。 -
ExecutorType.REUSE:该类型的执行器会复用预处理语句。 -
ExecutorType.BATCH:该类型的执行器会批量执行所有更新语句,如果 SELECT在多个更新中间执行,将在必要时将多条更新语句分隔开来,以方便理解。
|