根元素<configuration>,子元素:

  • <properties>
  • <setttings>
  • <typeAliases>
  • <typeHandlers>
  • <objectFactory>
  • <plugins>
  • <environments>
  • <databaseIdProvider>
  • <mappers>

这些子元素的配置是有顺序的,只能按照上面的顺序配置。

可缺省部分子元素。


<properties>

用于将内部的配置外在化,在<properties>中引入外部配置即可。

比如数据库的连接信息,我们可以直接写在全局配置文件中:

<environments default="development">
<environment id="development">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/my_db?serverTimezone=GMT"/>
<property name="username" value="chy"/>
<property name="password" value="abcd"/>
</dataSource>
</environment>
</environments>

考虑到更换数据库时,运维从一大堆代码不好找数据库的连接信息,我们可以把数据库的连接信息拿出来,单独写在一个配置文件中。

sql.properties:

mysql_driver=com.mysql.cj.jdbc.Driver
mysql_url=jdbc:mysql://localhost:3306/my_db?serverTimezone=GMT
mysql_username=chy
mysql_password=abcd
#oracle_driver=.....
#oracle_url=.....
#oracle_username=.....
#oracle_password=.....

mybatis-config.xml:

    <properties resource="sql.properties"></properties>

    <environments default="development">
<environment id="development">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="${mysql_driver}"/>
<property name="url" value="${mysql_url}"/>
<property name="username" value="${mysql_username}"/>
<property name="password" value="${mysql_password}"/>
</dataSource>
</environment>
</environments>

<settings>

用于设置mybatis运行时的参数。常用的项有:

  • cacheEnabled:是否使用缓存,boolean值,默认为false
  • lazyLoadingEnabled :是否使用懒加载,boolean值,默认为false
  • defaultStatementTimeout:设置超时时间,默认单位秒
  • mapUnderscoreToCamelCase:是否启用camel命名规则的映射,boolean值,默认为false
  • logImpl:使用的日志框架

一般只需配置logImpl:

<settings>
<setting name="logImpl" value="LOG4J"/>
</settings>

如果不使用日志框架,可以缺省此配置。


<typeAlias>

用于配置pojo类别名。

在映射文件中,如果parameterType、 resultType是自己写的pojo类,必须使用全限定类名:

resultType="com.chy.pojo.Student"

又臭又长,很麻烦。可以使用别名。

配置pojo类的别名:

<typeAliases>
<typeAlias type="com.chy.pojo.Student" alias="Student"/>
<typeAlias type="com.chy.pojo.Teacher" alias="Teacher"/>
</typeAliases>
resultType="Student"

直接写别名即可。

如果缺省alias属性,默认为类名的camel写法,比如Student => student。

也可以使用注解来配置pojo类的别名:

@Alias(value = "Student")
public class Student {
//......
}

可以缺省属性名,简写为

@Alias("Student")

如果觉得一个一个地配置pojo类很麻烦,可以使用包自动扫描:

<typeAliases>
<package name="com.chy.pojo"/>
</typeAliases>

这个包下所有的pojo类都使用camel命名方式的别名。

在映射文件中使用别名有一个缺点:Ctrl+左键不会转到定义处。


<typeHandlers>

将参数传给预处理语句时,需要将数据从javaType(java类型)转换为jdbcType(jdbc类型);

将结果集中的数据转换为指定类型时,需要将数据从jdbcType转换为javaType。

这2个过程都要用到typeHandler(类型转换器)。一般我们使用mybatis自带的类型转换器即可,也可以在<typeHandlers>中引用自定义的类型转换器。


<objectFactory>

ObjectFactory负责创建结果实例。

将查询结果映射为指定对象时,默认的ObjectFactory先调用无参的构造器创建pojo类的实例,再调用setter方法注入值。

一般我们使用默认的ObjectFactory即可,也可以在<objectFactory>中引用自定义的ObjectFactory类。


<plugins>

mybatis允许在将查询结果映射为指定类型的过程中,以插件形式执行自定义的代码。


<environments>

环境配置,mybatis是持久层框架,它的环境自然是数据库,即数据库的配置。

<environments default="development">
<environment id="development">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="${mysql_driver}"/>
<property name="url" value="${mysql_url}"/>
<property name="username" value="${mysql_username}"/>
<property name="password" value="${mysql_password}"/>
</dataSource>
</environment>
</environments>

一般要配置多个环境,开发一个环境,正式使用一个环境。default指定要使用哪个<environment>。

一个<environment>即一个环境(数据库配置)。

<transactionManager>指定使用哪种事务管理,通常使用JDBC的事务管理。如果搭配Spring使用,一般使用Spring的事务管理(在spring中配置事务管理),不在mybatis中配置事务。

<dataSource>配置数据源,mybatis提供了三种数据源:

  • UNPOOLED    不使用连接池
  • POOLED   使用连接池
  • JNDI   适合在在EJB或应用服务器等容器中使用

type指定使用哪种数据源,<property>子元素设置具体选项。

UNPOOLED

不使用连接池,适合对性能没有要求的、简单的应用程序。

常用属性:

  • driver、url、username、password
  • defaultTransactionlsolationLevel   设置默认的事务隔离级别

POOLED

操作数据库速度更快,适合高并发的程序,很常用。

常用属性:

  • driver、url、username、password
  • defaultTransactionlsolationLevel   设置默认的事务隔离级别
  • poolMaximumActiveConnections   最大活跃连接数
  • poolMaximumIdleConnections   最大闲置连接数

<mapper>

用于引入映射文件。写法很多,常用的有3种:

  • 通过映射文件的路径引入
<mappers>
<mapper resource="com/chy/mapper/StudentMapper.xml"/>
<mapper resource="com/chy/mapper/TeacherMapper.xml"/>
</mappers>
  • 通过mapper接口类引入
<mappers>
<mapper class="com.chy.mapper.StudentMapper"/>
</mappers>
  • 通过包名引入
<mappers>
<package name="com.chy.mapper"/>
</mappers>

这种最常用,可以一次性引入mapper包下所有的映射文件。

MyBatis 配置文件详解的更多相关文章

  1. ORM框架对比以及Mybatis配置文件详解

    ORM框架对比以及Mybatis配置文件详解 0.数据库操作框架的历程 (1) JDBC ​ JDBC(Java Data Base Connection,java数据库连接)是一种用于执行SQL语句 ...

  2. 02.MyBatis配置文件详解

        MyBatis入参考文档:http://mybatis.org/mybatis-3/zh/  1.properties 属性 1.在MyBatis配置文件中引用属性文件     MyBatis ...

  3. mybatis配置文件详解

    这是我看到的博文中最全的一篇了 参见:https://www.cnblogs.com/black-spike/p/7765732.html

  4. mybatis代码生成器配置文件详解

    mybatis代码生成器配置文件详解 更多详见 http://generator.sturgeon.mopaas.com/index.html http://generator.sturgeon.mo ...

  5. MyBatis核心配置文件详解

    ------------------------siwuxie095                                     MyBatis 核心配置文件详解         1.核心 ...

  6. 2017.2.9 深入浅出MyBatis技术原理与实践-第八章 MyBatis-Spring(二)-----配置文件详解

    深入浅出MyBatis技术原理与实践-第八章 MyBatis-Spring(二) ------配置文件详解 8.2 MyBatis-Spring应用 8.2.1 概述 本文主要讲述通过注解配置MyBa ...

  7. MyBatis 全局配置文件详解(七)

    MyBatis 配置文件作用 MyBatis配置文件包含影响 MyBatis 框架正常使用的功能设置和属性信息.它的作用好比手机里的设置图标,点击这个图标就可以帮助我们查看手机的属性信息和设置功能.其 ...

  8. 【JAVAEE学习笔记】hibernate01:简介、搭建、配置文件详解、API详解和CRM练习:保存客户

    今日学习:hibernate是什么 一.hibernate是什么 框架是什么: 1.框架是用来提高开发效率的 2.封装了好了一些功能.我们需要使用这些功能时,调用即可.不需要再手动实现. 3.所以框架 ...

  9. Mybatis配置详解

    一.SqlSession的使用范围说明  1.SQLSessionFactoryBuilder   通过SqlSessionFactoryBuilder创建会话工厂SqlSessionFactory, ...

随机推荐

  1. celery 使用 - 3

    # celery 使用 1.broker 2.基础案例 使用redis作为broker和brokend. 创建tasks.py # tasks.py di = 'redis://:****@local ...

  2. cas的单点登录实现

    1.  前提条件 环境:jdk1.8.shiro1.4.0及以上版本.项目以 spring+shiro构建 工具:buji-pac4j-3.1.0-jar-with-dependencies.jar以 ...

  3. CentOS 7----Apache基于域名的虚拟主机配置

    配置/etc/hosts文件,192.168.1.209 对应的域名如下: 192.168.1.209 www.name1.com 编辑每个域名的配置文件: <VirtualHost 192.1 ...

  4. Centos610快照克隆后网络配置

    VMware中安装的Centos610快照并克隆后网络配置 1.网卡配置 vi /etc/sysconfig/network-scripts/ifcfg-eth0 DEVICE=eth0 HWADDR ...

  5. 使用在线编辑 svg 软件修改 svg 图片

    网站需要使用图标字体,但设计师给的图标大小有问题,故使用下面说陈述方法简单修改了一下.使用到的在线编辑软件地址为:https://editor.method.ac/ 问题: 注:至于如何使用图标字体( ...

  6. RS232与RS485

    1.RS232实物图与引脚图? 2.RS485实物图与引脚图?

  7. Webflux是什么东东

    转自:百家号-薇薇心语 各位Javaer们,大家都在用SpringMVC吧?当我们不亦乐乎的用着SpringMVC框架的时候,Spring5.x又悄(da)无(zhang)声(qi)息(gu)的推出了 ...

  8. 最全的Java操作Redis的工具类,使用StringRedisTemplate实现,封装了对Redis五种基本类型的各种操作!

    转载自:https://github.com/whvcse/RedisUtil 代码 ProtoStuffSerializerUtil.java import java.io.ByteArrayInp ...

  9. 《创业者技能树》--创业课--14天复盘第一课candy2--HHR计划

    1,厉害的人是如何分析问题的?

  10. 关系型数据库中的jsonfield字段的优劣

    本人并非专业,开发经验也不太足,有一次在弄一个user数据表时,需要增加一些字段,又懒得去修改数据,就索性把这些属性封装在一个类中,序列化为json数据,存放在数据库的一个字段中了,后来,发现这么做至 ...