MyBatis 核心配置文件深入浅出

Posted 求不脱发

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MyBatis 核心配置文件深入浅出相关的知识,希望对你有一定的参考价值。

🙊🙊作者主页:🔗求不脱发的博客

📔📔 精选专栏:🔗SSM直击大厂

📋📋 精彩摘要:MyBatis 核心配置文件(xxxConfig.xml),该文件配置了MyBatis的一些全局信息,,包含数据库连接信息和MyBatis运行时所需的各种特性,以及设置和响应MyBatis行为的一些属性。本文将深入浅出的介绍MyBatis核心配置文件中常用的标签配置。

💞💞觉得文章还不错的话欢迎大家点赞👍➕收藏⭐️➕评论💬支持博主🤞


📚目录

📖MyBatis 核心配置文件深入浅出

1️⃣层级关系

2️⃣environments 环境标签

3️⃣mapper 映射标签

4️⃣Properties 配置文件标签

5️⃣typeAliases 定义别名标签

6️⃣typeHandlers 类型处理器标签

7️⃣plugins 第三方插件标签

8️⃣本章小结


📖MyBatis 核心配置文件深入浅出


1️⃣层级关系

  • configguration 配置
    • properties 属性
    • settings 设置
    • typeAliases 类型别名
    • typeHandlers 类型处理器
    • objectFactory 对象工厂
    • plugins 插件
    • environments 环境 
      • environment 环境变量
        • transactionManager 事务管理器
        • dataSource数据源
    • databaseIdProvider 数据库厂商标识
    • mappers 映射器

2️⃣environments 环境标签

事务管理器(transactionManager)类型有两种: 

                                                事务管理器(transactionManager)
JDBC:直接使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。
MANAGED:

它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如JEE 应用服务器的上下文)。 默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将 closeConnection 属性设置 为 false 来阻止它默认的关闭行为。

数据源(dataSource)类型有三种:

                                                                数据源(dataSource)
UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。
POOLED:这种数据源的实现利用“池”的概念将 JDBC 连接对象组织起来。
JNDI:

这个数据源的实现是为了能在如 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置 一个 JNDI 上下文的引用


📝3️⃣mapper 映射标签

该标签用于加载映射,加载方式有如下几种:

加载方式例:
使用相对于类路径资源引用(常用)<mapper resource="org/mybatis/builder/AuthorMapper.xml"/>
使用完全限定资源定位符(URL)<mapper url="file:///var/mappers/AuthorMapper.xml"/>
使用映射器接口实现类完全限定类名<mapper class="org.mybatis.builder.AuthorMapper"/>
包内映射器接口实现全部注册映射器<package name="org.mybatis.builder"/>

4️⃣Properties 配置文件标签

 实际开发中,习惯将数据源的配置信息单独抽取成一个properties文件,该标签可以加载额外配置的properties文件。

 <!--1、加载数据库相关配置文件db.properties-->
    <properties resource="db.properties"/>
 <!--2、配置数据源环境-->
    <environments default="mybatis">
        <environment id="mybatis">
            <transactionManager type="JDBC"></transactionManager>
            <dataSource type="POOLED">
                <property name="driver" value="$jdbc.driver"/>
                <property name="url" value="$jdbc.url"/>
                <property name="username" value="$jdbc.username"/>
                <property name="password" value="$jdbc.password"/>
            </dataSource>
        </environment>
    </environments>

5️⃣typeAliases 定义别名标签

User全限定名:com.mybatis.domain.User

使用typeAliases标签定义别名

<!--定义别名-->
    <typeAliases>
        <typeAlias type="com.mybatis.domain.User" alias="user"/>
    </typeAliases>

上面我们是自定义的别名,mybatis框架已经为我们设置好的一些常用的类型的别名

别名数据类型
stringString 
longLong
intInteger
doubleDouble
booleanBoolean
......

📝6️⃣typeHandlers 类型处理器标签

无论是 MyBatis 在预处理语句(PreparedStatement)中设置一个参数时,还是从结果集中取出一个值时, 都会用类型处理器将获取的值以合适的方式转换成 Java 类型。下表描述了一些默认的类型处理器(截取部分)。

类型处理器Java 类型JDBC 类型
BooleanTypeHandlerjava.lang.Boolean, boolean数据库兼容的 BOOLEAN
ByteTypeHandlerjava.lang.Byte, byte数据库兼容的 NUMERIC 或 BYTE
ShortTypeHandlerjava.lang.Short, short数据库兼容的 NUMERIC 或 SHORT INTEGER
IntegerTypeHandlerjava.lang.Integer, int数据库兼容的 NUMERIC 或 INTEGER
LongTypeHandlerjava.lang.Long, long数据库兼容的 NUMERIC 或 LONG INTEGER
FloatTypeHandlerjava.lang.Float, float数据库兼容的 NUMERIC 或 FLOAT
DoubleTypeHandlerjava.lang.Double, double数据库兼容的 NUMERIC 或 DOUBLE
BigDecimalTypeHandlerjava.math.BigDecimal数据库兼容的 NUMERIC 或 DECIMAL
StringTypeHandlerjava.lang.StringCHAR, VARCHAR
ClobTypeHandlerjava.lang.StringCLOB, LONGVARCHAR
NStringTypeHandlerjava.lang.StringNVARCHAR, NCHAR
NClobTypeHandlerjava.lang.StringNCLOB
ByteArrayTypeHandlerbyte[]数据库兼容的字节流类型
BlobTypeHandlerbyte[]BLOB, LONGVARBINARY
DateTypeHandlerjava.util.DateTIMESTAMP
DateOnlyTypeHandlerjava.util.DateDATE
TimeOnlyTypeHandlerjava.util.DateTIME
SqlTimestampTypeHandlerjava.sql.TimestampTIMESTAMP
SqlDateTypeHandlerjava.sql.DateDATE
SqlTimeTypeHandlerjava.sql.TimeTIME
ObjectTypeHandlerAnyOTHER 或未指定类型 
EnumTypeHandlerEnumeration Type VARCHAR-任何兼容的字符串类型,存储枚举的名称(而不是索引)
EnumOrdinalTypeHandlerEnumeration Type任何兼容的 NUMERIC 或 DOUBLE 类型,存储枚举的索引(而不是名称)。 

可以重写类型处理器或创建自己的类型处理器来处理不支持的或非标准的类型。

具体的做法为:

  1. 实现org.apache.ibatis.type.TypeHandler接口,或继承一个很便利的类org.apache.ibatis.type.BaseTypeHandler,
  2. 然后可以选择性地将它映射到一个JDBC类型。

例如需求:

        一个Java中的Date数据类型,我想将之存到数据库的时候存成一个1970年至今的毫秒数,取出来时转换成java的Date,即java的Date与数据库的varchar毫秒值之间转换。

开发步骤:

① 定义转换类继承类BaseTypeHandler<T>

② 覆盖4个未实现的方法,其中setNonNullParameter为java程序设置数据到数据库的回调方法,getNullableResult 为查询时 mysql的字符串类型转换成 java的Type类型的方法

public class MyDateTypeHandler extends BaseTypeHandler<Date> 
	public void setNonNullParameter(PreparedStatement preparedStatement, int i, Date date, JdbcType type) 
		preparedStatement.setString(i, date.getTime() + "");
	

	public Date getNullableResult(ResultSet resultSet, String s) throws SQLException 
		return new Date(resultSet.getLong(s));
	

	public Date getNullableResult(ResultSet resultSet, int i) throws SQLException 
		return new Date(resultSet.getLong(i));
	

	public Date getNullableResult(CallableStatement callableStatement, int i) throws SQLException 
		return callableStatement.getDate(i);
	

③ 在MyBatis核心配置文件中进行注册

<!--注册类型自定义转换器--> 
<typeHandlers>
 <typeHandler handler="com.mybatis.typeHandlers.MyDateTypeHandler"></typeHandler>
</typeHandlers>

④ 直接使用即可


7️⃣plugins 第三方插件标签

MyBatis 可以使用第三方的插件来对功能进行扩展。

例如分页助手 PageHelper 是将分页的复杂操作进行封装,使用简单的方式即可获得分页的相关数据。

开发步骤:

  1. 在 pom.xml 导入通用PageHelper的坐标
    <!-- 分页助手 --> 
    <dependency>
     <groupId>com.github.pagehelper</groupId>
     <artifactId>pagehelper</artifactId>
     <version>3.7.5</version>
    </dependency> 
    <dependency>
     <groupId>com.github.jsqlparser</groupId>
     <artifactId>jsqlparser</artifactId>
     <version>0.9.1</version>
    </dependency>
  2. 在mybatis核心配置文件中配置PageHelper插件
    <!-- 注意:分页助手的插件 配置在mapper之前 --> 
    <plugin interceptor="com.github.pagehelper.PageHelper">
        <!-- 指定方言 -->
        <property name="dialect" value="mysql"/>
    </plugin>
  3. PageHelper相关API
PageHelper. startPage ( int  pagenum , int pagesize ); 设置分页参数,当前页,当前页展示的条数
获取其他分页的数据 可使用  PageInfo  PageInfo<User> pageInfo = new PageInfo<User>(List<T>  T );
pageInfo.getTotal() 总条数
pageInfo.getPages() 总页数
pageInfo.getPageNum() 当前页
pageInfo.getPageSize()) 当前页展示的条数
pageInfo.isIsFirstPage() 当前页是否为第一页
pageInfo.isIsLastPage() 当前页是否为最后一页

8️⃣本章小结

MyBatis核心配置文件常用标签:

1️⃣environments 环境标签

2️⃣mapper 映射标签

3️⃣Properties 配置文件标签

4️⃣typeAliases 定义别名标签

5️⃣typeHandlers 类型处理器标签

6️⃣plugins 第三方插件标签

以上是关于MyBatis 核心配置文件深入浅出的主要内容,如果未能解决你的问题,请参考以下文章

MyBatis 核心配置文件深入浅出

Mybatis -- MyBatis核心配置文件深入: typeHandlers标签(自定义类型转换器)plugins标签(插件标签:扩展mybatis功能 分页助手)

MyBatis

深入理解java:4.3.1. 框架编程之MyBatis---SQL语句执行的完整流程

深入详解Mybatis的架构原理与6大核心流程

MyBatis核心配置文件