MyBatis的映射文件Mapper和核心配置文件SqlMapperConfig概述
文章目录
1.映射文件概述
其他的以后补充…
2.核心配置文件概述
2.1 MyBatis核心配置文件层级关系
2.2MyBatis常用配置解析
1.environments标签
数据库环境的配置,支持多环境配置
<!--配置数据库连接环境-->
<environments default="development">
<!--development环境-->
<environment id="development">
<!--使用JDBC的事务管理器-->
<transactionManager type="JDBC"/>
<!--使用数据库连接池-->
<dataSource type="POOLED">
<!--连接属性-->
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/test"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments>
其中,事务管理器(transactionManager)类型有两种:
JDBC
:这个配置就是直接使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。MANAGED
:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如 JEE
应用服务器的上下文)。 默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将 closeConnection 属性设置
为 false 来阻止它默认的关闭行为。
其中,数据源(dataSource)类型有三种:UNPOOLED
:这个数据源的实现只是每次被请求时打开和关闭连接。POOLED
:这种数据源的实现利用“池”的概念将 JDBC 连接对象组织起来。JNDI
:这个数据源的实现是为了能在如 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个 JNDI 上下文的引用。
2.mapper标签
<!--配置Mapper-->
<mappers>
<mapper resource="mapper/UserMapper.xml"/>
</mappers>
该标签的作用是加载映射的,加载方式有如下几种:
- 使用相对于类路径的资源引用,例如:
- 使用完全限定资源定位符(URL),例如:
- 使用映射器接口实现类的完全限定类名,例如:
- 将包内的映射器接口实现全部注册为映射器,例如:
3.Properties标签
实际开发中,习惯将数据源的配置信息单独抽取成一个properties文件,该标签可以加载额外配置的properties文件
<!--加载外置的properties文件-->
<properties resource="jdbc.properties"></properties>
4.typeAliases标签
类型别名是为Java 类型设置一个短的名字。原来的类型名称配置如下
- 使用完整的全限定类名,
<mapper namespace="UserMapper">
<select id="findAll" resultType="com.other.domain.User">
select * from sys_user;
</select>
</mapper>
- 使用typeAliases 表示全限定类名
//--------------SqlMapperConfig.xml----------------
<!--给类设置别名-->
<typeAliases>
<typeAlias type="com.other.domain.User" alias="user"/>
</typeAliases>
//---------------UserMapper.xml---------------------
<mapper namespace="UserMapper">
<select id="findAll" resultType="user">
select * from sys_user;
</select>
</mapper>
上面我们是自定义的别名, mybatis框架已经为我们设置好的一些常用的类型的别名