电商网站开题报告,优秀网站的颜色搭配,做软件的网站建设,南庄网站开发在 MyBatis 中#xff0c;SqlSession 是其核心接口。在 MyBatis 中有两个实现类#xff0c;DefaultSqlSession 和 SqlSessionManager。
SqlSession是Mybatis的一个核心类#xff0c;简单点就是执行sql的#xff0c;Mybatis的一级缓存应该就在这个级别上的#xff0c;实际…在 MyBatis 中SqlSession 是其核心接口。在 MyBatis 中有两个实现类DefaultSqlSession 和 SqlSessionManager。
SqlSession是Mybatis的一个核心类简单点就是执行sql的Mybatis的一级缓存应该就在这个级别上的实际上一级缓存在Executor中实现的下个文章介绍。
先看看SqlSession中的方法 DefaultSqlSession 是单线程使用的而 SqlSessionManager 在多线程环境下使用。SqlSession 的作用类似于一个 JDBC 中的 Connection 对象代表着一个连接资源的启用。具体而言它的作用有 3 个
获取 Mapper 接口。发送 SQL 给数据库。控制数据库事务。先来掌握它的创建方法有了 SqlSessionFactory 创建的 SqlSession 就十分简单了如下所示。
SqlSession sqlSession SqlSessionFactory.openSession();
注意SqlSession 只是一个门面接口它有很多方法可以直接发送 SQL。它就好像一家软件公司的商务人员是一个门面而实际干活的是软件工程师。在 MyBatis 中真正干活的是 Executor我们会在底层看到它。 SqlSession 控制数据库事务的方法如下所示。
//定义 SqlSession
SqlSession sqlSession null;
try {// 打开 SqlSession 会话sqlSession SqlSessionFactory.openSession();// some code...sqlSession.commit(); // 提交事务
} catch (IOException e) {sqlSession.rollback(); // 回滚事务
}finally{// 在 finally 语句中确保资源被顺利关闭if(sqlSession ! null){sqlSession.close();}
} 这里使用 commit 方法提交事务或者使用 rollback 方法回滚事务。因为它代表着一个数据库的连接资源使用后要及时关闭它如果不关闭那么数据库的连接资源就会很快被耗费光整个系统就会陷入瘫痪状态所以用 finally 语句保证其顺利关闭。