百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

深入MyBatis配置文件(mybatis 配置文件)

sinye56 2024-09-27 21:27 11 浏览 0 评论

我们都知道MyBatis的持久化操作离不开SqlSessionFactory对象,这个对象是整个数据库映射关系经过编译后的内存镜像,该对象的openSession()方法可以打开SqlSession对象.该对象由由SqlSessionFactoryBuilder加载MyBatis的配置文件产生.

先贴一张MyBatis初始化的基本过程,如下图:

上图所示,MyBatis初始化要经过以下几步:

  1. 调用 SqlSessionFactoryBuilder 对象的build(inputStream)方法;

  2. SqlSessionFactoryBuilder 会根据输入流inputStream等信息创建 XMLConfigBuilder 对象;

  3. SqlSessionFactoryBuilder 调用 XMLConfigBuilder 对象的parse()方法;

  4. XMLConfiguBuilde r对象解析XML配置文件返回 Configuration 对象;

  5. SqlSessionFactoryBuilder 根据 Configuration 对象创建一个 DefaultSessionFactory 对象;

  6. SqlSessionFactoryBuilder 返回 DefaultSessionFactory 对象给客户端,供客户端调用;

由此可见,SqlSessionFactory是根据MyBatis的配置文件 mybatis-config.xml 创建的,接下来我们就来重点研究下MyBatis配置文件中常用属性的意义.

MyBatis的配置文件结构

MyBatis的配置文件包含了影响MyBatis行为的信息,文档的结构如下:

顶层configuration配置

  • properties 属性

  • settings 设置

  • typeAliases 类型命名

  • typeHandlers 类型处理器

  • objectFactory 对象工厂

  • plugins 插件

  • environments 环境

  • transactionManager 事务管理器

  • dataSource 数据源

  • environment 环境变量

  • databaseIdProvider 数据库厂商标识

  • mappers 映射器

properties属性

这些属性都是可外部配置且可动态替换的,既可以在典型的Java属性文件中配置,亦可通过properties元素的子元素来传递.

可以再CLASSPATH中增加一个db.properties的Java属性文件.

driver=oracle.jdbc.driver.OracleDriverur=jdbc:oracle:thin:@127.0.0.1:1526:mybatisusername=rootpassword=root

在配置文件中配置<properties.../>属性:

<properties resource="db.properties"/>

其中的属性就可以在整个配置文件中使用来替换需要动态配置的属性值.

<dataSource type="POOLED">
 <property name="driver" value="${driver}"/>
 <property name="url" value="${url}"/>
 <property name="username" value="${username}"/>
 <property name="password" value="${password}"/>
</dataSource>

settings设置

一个配置完成的settings元素示例如下,具体含义这里不再列举,可以自行google.

typeAliases 类型命名

类型别名是为Java类型设置的一个短的名字.它只和XML配置有关,存在的意义仅在于用来减少类完全限定名的冗余.

<typeAliases>
<typeAlias alias="user" type="org.ccgogoing.domian.User"/>
</typeAliases>

当这样配置时,user可以用在任何使用org.ccgogoing.domain.User的地方.

也可以指定一个包名,MyBatis会在包名下面搜索需要的Java Bean

<typeAliases>
<package name="org.ccgogoing.domian"/></typeAliases>

每一个在包org.ccgogoing.domain中的Java Bean,在没有注解的情况下,会使用Bean的首字母小写的非限定类名来作为它的别名.比如 org.ccgogoing.domain.User 的别名为user,若有注解,则别名为其注解值.

@Alias("user")public class User {
...
}

typeHandlers 类型处理器

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

objectFactory 对象工厂

MyBatis每次创建结果对象的新实例时,它都会使用一个对象工厂(ObjectFactory)实例来完成.默认的对象工厂需要做的仅仅是实例化目标类,要么通过默认构造方法,要买在参数映射存在的时候通过参数构造方法来实例化.如果想覆盖对象工厂的默认行为,则可以通过创建自己的对象工厂来实现.

environments 配置环境

MyBatis的环境配置实际就是数据源的配置.MyBatis可以配置多种环境,这种机制使得MyBatis可以将SQL映射应用于多种数据库中.例如,开发,测试盒生产环境需要不同的配置;多个生产数据库想使用相同的sql映射,等等.

尽管可以配置多个环境,但是每个SqlSessionFactory实例只能选择一个环境,即每个数据库对应一个SqlSessionFactory实例.所以如果你想连接两个数据库,就需要创建两个SqlSessionFactory实例,每个数据库对应一个.

环境配置示例如下:

<environments default="development">
 <environment id="development">
 <!--指定事务管理类型,type="JDBC"指直接简单使用了JDBC的提交和回滚事务-->
 <transactionManager type="JDBC"></transactionManager>
 <!-- dateSource指定数据源配置,POOLED是jdbc连接对象的数据源连接池的实现-->
 <dataSource type="POOLED">
 <property name="driver" value="${driver}"/>
 <property name="url" value="${url}"/>
 <property name="username" value="${username}"/>
 <property name="password" value="${password}"/>
 </dataSource>
 </environment>
 </environments>

默认的环境ID(default="development");

每个environment元素定义的环境ID(比如,id="development").

环境ID可以随意命名,建议简洁有意义,而默认环境一定要匹配定义的其中一个环境ID.

<transactionManager.../>表示事务管理配置,在MyBatis中有 JDBCMANAGED 两中类型的事务管理器:

  • JDBC.这个配置就是直接使用了JDBC的提交和回滚设置,它依赖于从数据源得到的连接来管理事务范围.

  • MANAGED. 这个配置几乎没做什么.它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如JAVAEE应用服务器的上下文).默认情况下它会关闭连接,然而一些容器并不希望这样,可以将closeConnection属性设置为false来阻止它的默认关闭行为.

<transactionManager type="MANAGED">
<property name="closeConnection" value="false"/>
</transactionManager>

提示: 如果开发使用Spring+MyBatis,则没有必要配置事务管理器,因为Spring模块会使用自带的管理器来覆盖前面的配置.

<dataSource.../>表示数据源配置,在MyBatis中有UNPOOLED、POOLED和JNDI三种数据源类型:

  • UNPOOLED.这个数据源的实现只是每次被请求时打开和关闭连接。它对没有性能要求的简单应用程序是一个很好的选择。不同的数据库在这方面表现也是不一样的。

    UNPOOLED类型的数据源仅仅需要配置一下5种属性:

    drive、url、username、password、defaultTransactionIsolationLevel。默认的连接事务隔离级别。

  • POOLED:这种数据源的实现利用“池”的概念将JDBC连接对想组织起来,避免了创建新的连接实例时所必需的初始化时间和认证时间。这是一种使得并发Web应用快速响应请求的流行处理方式,除了上述提到的UNPOOLED的5中属性外,还可以使用更多的属性来配置POOLED的数据源:

  • poolMaximumActiveConnections.在任意时间可以存在的活动(也就是正在使用)连接数量,默认值是10.

  • poolMaximumIdleConnections.任意时间可能存在的空闲连接数.

  • poolMaximunCheckoutTime.在被强制返回之前,池中连接被检出时间,默认值为20000毫秒(即20秒).

  • poolTimeToWait.这是一个底层设置,如果获取连接花费相当长的时间,它会给连接池打印状态日志并重新尝试获取一个连接(避免在误配置的情况下一直安静地失败),默认值为20000毫秒(20秒).

  • poolPingQuery.发送到数据库的侦测查询,用来检验连接是否处于正在工作秩序中并准备接受请求.默认是"NO PING QUERY SET",这会导致多数数据库驱动失败时带有一个恰当的错误消息.

  • poolPingEnabled.是否启用侦测查询.若开启,也必须使用一个可执行的sql语句设置poolPingQuery属性(最好是一个非常快的sql),默认值为false.

  • poolPingConnectionsNotUsedFor.配置poolPingQuery的使用频度.这可以被设置成匹配具体的数据库连接超时时间,来避免不必要的侦测,默认值为0(即所有连接每一时刻都被侦测,当然仅当poolPingEnabled为true时适用).

  • JNDI.这个数据源的实现是为了能在如EJB或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个JNDI上下文的引用.这种数据源配置只需要两个属性如下图所示:

mapper 映射器

MyBatis需要开发者自己写sql语句,mapper映射器正是告诉MyBatis到哪里去找映射文件,进而找到这些sql语句.实际开发中可以使用相对于类路径的资源引用或完全限定资源定位符(包括file:///的URL),以及类名和包名等,例如:

<!-- 使用类路径查找资源文件 -->
 <mappers>
 <mapper resource="com/ccgogoing/fileupload/mapper/sqlmap-mapping-user.xml"/>
 </mappers>
 <!-- 使用本地文件 -->
 <mappers>
 <mapper url="file:///C:/mapper/UserMapper.xml">
 </mappers>
 <!-- 使用接口类 -->
 <mappers>
 <mapper class="org.ccgogoing.mapper.UserMapper"
 </mappers>
 <!-- 使用包名 -->
 <mappers>
 <package name="org.ccgogoing.mapper"/>
 </mappers>

相关推荐

程序员:JDK的安装与配置(完整版)_jdk的安装方法

对于Java程序员来说,jdk是必不陌生的一个词。但怎么安装配置jdk,对新手来说确实头疼的一件事情。我这里以jdk10为例,详细的说明讲解了jdk的安装和配置,如果有不明白的小伙伴可以评论区留言哦下...

Linux中安装jdk并配置环境变量_linux jdk安装教程及环境变量配置

一、通过连接工具登录到Linux(我这里使用的Centos7.6版本)服务器连接工具有很多我就不一一介绍了今天使用比较常用的XShell工具登录成功如下:二、上传jdk安装包到Linux服务器jdk...

麒麟系统安装JAVA JDK教程_麒麟系统配置jdk

检查检查系统是否自带java在麒麟系统桌面空白处,右键“在终端打开”,打开shell对话框输入:java–version查看是否自带java及版本如图所示,系统自带OpenJDK,要先卸载自带JDK...

学习笔记-Linux JDK - 安装&amp;配置

前提条件#检查是否存在JDKrpm-qa|grepjava#删除现存JDKyum-yremovejava*安装OracleJDK不分系统#进入安装文件目...

Linux新手入门系列:Linux下jdk安装配置

本系列文章是把作者刚接触和学习Linux时候的实操记录分享出来,内容主要包括Linux入门的一些理论概念知识、Web程序、mysql数据库的简单安装部署,希望能够帮到一些初学者,少走一些弯路。注意:L...

测试员必备:Linux下安装JDK 1.8你必须知道的那些事

1.简介在Oracle收购Sun后,Java的一系列产品就被整合到Oracle官网中,打开官网乍眼一看也不知道去哪里下载,还得一个一个的摸索尝试,而且网上大多数都是一些Oracle收购Sun前,或者就...

Linux 下安装JDK17_linux 安装jdk1.8 yum

一、安装环境操作系统:JDK版本:17二、安装步骤第一步:下载安装包下载Linux环境下的jdk1.8,请去官网(https://www.oracle.com/java/technologies/do...

在Ubuntu系统中安装JDK 17并配置环境变量教程

在Ubuntu系统上安装JDK17并配置环境变量是Java开发环境搭建的重要步骤。JDK17是Oracle提供的长期支持版本,广泛用于开发Java应用程序。以下是详细的步骤,帮助你在Ubuntu系...

如何在 Linux 上安装 Java_linux安装java的步骤

在桌面上拥抱Java应用程序,然后在所有桌面上运行它们。--SethKenlon(作者)无论你运行的是哪种操作系统,通常都有几种安装应用程序的方法。有时你可能会在应用程序商店中找到一个应用程序...

Windows和Linux环境下的JDK安装教程

JavaDevelopmentKit(简称JDK),是Java开发的核心工具包,提供了Java应用程序的编译、运行和开发所需的各类工具和类库。它包括了JRE(JavaRuntimeEnviro...

linux安装jdk_linux安装jdk软连接

JDK是啥就不用多介绍了哈,外行的人也不会进来看我的博文。依然记得读大学那会,第一次实验课就是在机房安装jdk,编写HelloWorld程序。时光飞逝啊,一下过了十多年了,挣了不少钱,买了跑车,娶了富...

linux安装jdk,全局配置,不同用户不同jdk

jdk1.8安装包链接:https://pan.baidu.com/s/14qBrh6ZpLK04QS8ogCepwg提取码:09zs上传文件解压tar-zxvfjdk-8u152-linux-...

运维大神教你在linux下安装jdk8_linux安装jdk1.7

1.到官网下载适合自己机器的版本。楼主下载的是jdk-8u66-linux-i586.tar.gzhttp://www.oracle.com/technetwork/java/javase/downl...

window和linux安装JDK1.8_linux 安装jdk1.8.tar

Windows安装JDK1.8的步骤:步骤1:下载JDK打开浏览器,找到JDK下载页面https://d.injdk.cn/download/oraclejdk/8在页面中找到并点击“下载...

最全的linux下安装JavaJDK的教程(图文详解)不会安装你来打我?

默认已经有了linux服务器,且有root账号首先检查一下是否已经安装过java的jdk任意位置输入命令:whichjava像我这个已经安装过了,就会提示在哪个位置,你的肯定是找不到。一般我们在...

取消回复欢迎 发表评论: