一、Mybatis 核心配置文件概述
1. MyBatis 核心配置文件层级关系
2. MyBatis 常用配置解析
(1)environments 标签
数据库环境的配置,支持多环境配置
事务管理器(transactionManager)类型:
JDBC:这个配置就是直接使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。
MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如 JEE 应用服务器的上下文)。 默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将 closeConnection 属性设置为 false 来阻止它默认的关闭行为。
数据源(dataSource)类型:
UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。
POOLED:这种数据源的实现利用“池”的概念将 JDBC 连接对象组织起来。
JNDI:这个数据源的实现是为了能在如 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个 JNDI 上下文的引用。
(2)mapper 标签
该标签的作用是加载映射的
(3)properties 标签
将数据源的配置信息单独抽取成一个properties 文件,该标签可以加载额外配置的properties 文件
(3)typeAliases 标签
类型别名是为Java 类型设置一个短的名字(别名)。
MyBatis 框架已经设置了一些常用的类型的别名
一、Mybatis 相应API
1. SqlSession 工厂构建器SqlSessionFactoryBuilder
常用API:SqlSessionFactory build(InputStream inputStream)
通过加载MyBatis 的核心文件的输入流的形式构建一个SqlSessionFactory 对象
其中,Resources 工具类,这个类在org.apache.ibatis.io 包中。Resources 类从类路径下、文件系统或一个web URL 中加载资源文件。
2. SqlSession 工厂对象SqlSessionFactory
SqlSessionFactory 有多个方法创建SqlSession实例。
3. SqlSession 会话对象
SqlSession 实例在MyBatis 中是非常强大的一个类。
执行语句的方法:
操作事务的方法: