0


【MyBatis框架】核心配置文件讲解

14天阅读挑战赛

目录

1. 引言

在MyBatis的核心配置中,包含了很多影响MyBatis行为的重要信息,这些信息通常在一个项目中只会在一个配置文件中编写,并且编写后也不会轻易改动。虽然在实际项目中需要开发人员编写或修改的配置文件不多,但是熟悉配置文件中各个元素的功能还是十分重要的。

2. 主要元素

在MyBatis框架的核心配置文件中,< configuration >元素是配置文件的根元素,其他元素都要在< configuration >元素内进行配置,其配置文件的主要元素如图

在这里插入图片描述

从图中可以看出,在MyBatis的配置文件中包含了 多个元素,这些元素在配置文件中分别发挥着不同的作用。开发人员索要熟悉的就是图中的< configuration >元素各个子元素的配置。

这里要特别注意,< configuration >的子元素必须按照图中由上到下的顺序进行配置,否则MyBatis在解析XML文件的时候会报错

3. 常用配置元素介绍

3.1 < properties >

< properties >是一个配置属性的元素,该元素常用于将内部的配置外在化,即通过外部的配置来动态的替换内部定义的属性,例如数据库的连接等属性,就可以通过配置文件进行转化。

配置个人数据库连接配置

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/zxy_db01
jdbc.username=root
jdbc.pwd=zxy

在这里插入图片描述

3.2 < settings >

< settings >元素主要用于改变MyBatis运行时的行为,例如开启二级缓存,开启延迟加载等。即使不配置< settings >元素,也可以正常运行MyBatis。但是熟悉其中的元素还是很有必要的。
在这里插入图片描述

其常见使用方式如下

在这里插入图片描述

3.3 < typeAliases >

< typeAliases >元素用于给配置文件中的Java类型起别名。

<typeAliases><!--
        typeAlias:设置某个类型的别名
        属性:
        type:设置需要设置别名的类型
        alias:设置某个类型的别名,若不设置该属性,那么该类型拥有默认的别名,即类名
        且不区分大小写
        --><typeAliasalias="user"type="com.zxy.mybatis.pojo.User"></typeAlias></typeAliases>

当POJO类过多时,可以通过自动扫描包的形式自定义别名

<typeAliases><!--以包为单位,将包下所有的类型设置默认的类型别名,即类名且不区分大小写--><packagename="com.zxy.mybatis.pojo"/></typeAliases>

默认会以首字母小写的方式来取别名。

除了可以使用 < typeAliases >元素自定义别名外,MyBatis框架还默认为许多常见的

Java

类型提供了相应地类型别名

在这里插入图片描述

3.4 < typeHandlers >

MyBatis在预处理语句中设置一个参数或者从结果集中取出一个值时,都会用其框架内部注册的

typeHandler

(类型处理器)进行相关处理。

typeHandler

的作用就是将预处理语句中传入的参数从

javaType

(java类型)转换为

dbcType

(JDBC类型),或者从数据库去除结果时将

jdbcType

转换成

javaType

在这里插入图片描述

具体使用方式如下

  1. 注册一个类的类型处理器
<typeHandlers><typeHandlerhandler="com.zxy.type。Hander"/></typeHandlers>
  1. 注册一个包中所有元素的类型处理器
<typeHandlers><packagename="com.zxy.type"/></typeHandlers>

3.5 < plugins >

< plugins >元素的作用是配置用户所开发的插件

3.6 < environments >

在配置文件中,< environments >用于对环境进行配置,MyBatis的环境配置实际上就是数据源的配置,我们可以通过对< environments >元素配置多种数据源,即配置多种数据库。

<environmentsdefault="development"><environmentid="development"><transactionManagertype="JDBC"/><dataSourcetype="POOLED"><!--设置连接数据库的驱动--><propertyname="driver"value="${jdbc.driver}"/><!--设置连接数据库的连接地址--><propertyname="url"value="${jdbc.url}"/><!--设置连接数据库的用户名--><propertyname="username"value="${jdbc.username}"/><!--设置连接数据库的密码--><propertyname="password"value="${jdbc.password}"/></dataSource></environment></environments>

在MyBatis中,可以配置两种类型的事务管理器,分别是

JDBC

MANAGED

,关于这两个事务管理器的描述如下:

  1. JDBC:此配置使用了JDBC的提交和回滚设置,它依赖于从数据源得到的连接来管理事物的作用域。
  2. MANAGED:此配置从来不提交或回滚一个连接,而是让容器来管理事物的整个生命周期。在默认情况下,它会关闭连接,但一些容器并不希望这样,为此可以将closeConnection的属性设置为false来阻止它的默认行为。

3.7 < mappers >

在配置文件中,< mappers >元素用于指定MyBatis映射文件的位置,一般可以使用如下4种方式引入映射器文件。

  1. 类路径引入<mappers><mapperresource="com/zxy/mybatis/mapper/UserMapper.xml"/></mappers>
  2. 本地文件路径引入<mappers><mapperurl="file:///D:/com/zxy/mapper/UserMapper.xml"/></mappers>
  3. 使用接口类引入<mappers><mapperclass="com.zxy.mybatis.mapper.UserMapper.xml"/></mappers>
  4. 使用包名引入<mappers><mappername="com.zxy.mybatis.mapper"/></mappers>

4. 结语

MyBatis的核心配置文件是十分重要的,关系着框架是否能正常运转,应该多熟悉结构,比如本人曾经写错了 < mappers >的配置导致映射文件找不到,十分头痛。

标签: mybatis java mysql

本文转载自: https://blog.csdn.net/m0_64102491/article/details/127393346
版权归原作者 叁 柒 所有, 如有侵权,请联系我们删除。

“【MyBatis框架】核心配置文件讲解”的评论:

还没有评论