`
情情说
  • 浏览: 39089 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

深入浅出MyBatis:MyBatis的所有配置

 
阅读更多

上一篇介绍了JDBC的相关概念、MyBatis的特性与Hibernate的区别、MyBatis的基本组件与生命周期,基本可以使用MyBatis了。

这一篇详细介绍MyBatis的配置,首先看下配置XML文件的层次结构,然后详细介绍每个配置项,说明每项的作用,值的取值与含义。

下面列出MyBatis配置XML文件的层次结构,这些层次是不能够颠倒顺序的。

<?xml version="1.0" encoding="UTF-8"?>  
<configuration>  
    <properties/>  
    <settings/>  
    <typeAliases/>  
    <typeHandles/>  
    <objectFactory/>  
    <plugins/>  
    <environments>  
        <environment>  
            <transanctionManager/> <!-- 配置事务管理器 -->  
            <dataSource/> <!-- 配置数据源 -->  
        </environment>  
    </environments>  

    <databaseIdProvider/> <!-- 数据库厂商标识 -->  
    <mappers/> <!-- 映射器 -->  
</configuration>

properties元素

将一些公用、经常变更的值单独声明,能在配置文件的上下文中使用它,MyBatis提供了3种配置方式:

  • property子元素
  • properties配置文件
  • 程序参数传递
property子元素
    <properties>
        <property name="driver" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/mi-user"/>
        <property name="username" value="root"/>
        <property name="pwd" value="123456"/>
    </properties>
properties配置文件

创建一个配置文件 jdbc.properties

driver = com.mysql.jdbc.Driver
url = jdbc:mysql://localhost:3306/mi-user
username = root
password = 123456

设置properties配置文件

 <properties resource='jdbc.properties' />
程序参数传递

实际工作中,会遇到这种场景:系统由运维人员配置,生成数据库的密码对开发者是保密的,对用户名和密码进行了加密。可以通过程序参数传递的方式,先解密,再设置property。

//读入配置文件流
InputStream cfgStream = Resources.getResourceAsStream("mybatis-config.xml");
Reader cfgReader = new InputStreamReader(cfgStream);

//读入属性文件流
InputStream proStream = Resources.getResourceAsStream("jdbc.properties");
Reader proReader = new InputStreamReader(proStream);

Properties properties = new Properties();
properties.load(proReader);
//转换为明文
properties.setProperty("username",decode(properties.getProperty("username")));
properties.setProperty("pwd",decode(properties.getProperty("pwd")));

//创建sqlSessionFactory
SqlSessionFactory sqlSessionFactory=new SqlSessionFactoryBuilder().build(cfgReader,properties);

如果3种配置同时出现,优先级为第3种 > 第2种 > 第1种,推荐使用第2种,有特殊需求时使用第3种。

设置

设置会改变MyBatis运行时的行为,设置项很多,只会介绍常用的配置,想了解全部配置可以查看官方文档。

  • cacheEnabled,全局地开启或关闭配置文件中的所有映射器已经配置的任何缓存,默认为true;
  • lazyLoadingEnabled,延迟加载的全局开关,当开启时,所有关联对象都会延迟加载,特定关联关系中可通过设置fetchType属性来覆盖该项的开关状态,默认为false;
  • aggressiveLazyLoading,当开启时,任何方法的调用都会加载该对象的所有属性。否则,每个属性会按需加载,3.4.1版本之前默认为true,3.4.1之后默认为false;
  • autoMappingBehavior,指定MyBatis应如何自动映射列到字段或属性,NONE 表示取消自动映射,PARTIAL 只会自动映射没有定义嵌套结果集映射的结果集,FULL 会自动映射任意复杂的结果集,默认为PARTIAL;
  • autoMappingUnknownColumnBehavior,指定发现自动映射目标未知列(或者未知属性类型)的行为,NONE: 不做任何反应,WARNING: 输出提醒日志,FAILING: 映射失败,默认为NONE;
  • defaultStatementTimeout,设置超时时间,它决定驱动等待数据库响应的秒数;
  • mapUnderscoreToCamelCase,是否开启自动驼峰命名规则(camel case)映射,即从经典数据库列名 A_COLUMN 到经典 Java 属性名 aColumn 的类似映射,默认为false;
  • defaultEnumTypeHandler,指定 Enum 使用的默认 TypeHandler,默认为org.apache.ibatis.type.EnumTypeHandler;
  • returnInstanceForEmptyRow,当返回行的所有列都是空时,MyBatis默认返回null。 当开启这个设置时,MyBatis会返回一个空实例,默认为false;
  • localCacheScope,MyBatis 利用本地缓存机制(Local Cache)防止循环引用(circular references)和加速重复嵌套查询。 默认值为 SESSION,这种情况下会缓存一个会话中执行的所有查询。 若设置值为 STATEMENT,本地会话仅用在语句执行上,对相同 SqlSession 的不同调用将不会共享数据,默认为SESSION;
  • logImpl,指定日志的具体实现,比如SLF4J|LOG4J|COMMONS_LOGGING等;

别名

在配置映射文件中,需要指定类的全限定名,为了简化,可以声明一个简短的名称去指代它,可以在MyBatis上下文中使用。系统已经为我们定义了常用的类型,比如数值、字符串、日期、集合等。对于自定义的业务POJO,需要自定义别名。

<typeAliases>
     <typeAlias alias="role" type="com.learn.chapter2.po.Role"/>
</typeAliases>

也可以通过注解方式进行,首先配置一个扫描的包,然后在类定义时添加注解@Alias(“role”)。

<typeAliases>
     <package name="com.learn.chapter2.po" />
</typeAliases>
@Alias("role")
public class Role{
}

类型处理器

MyBatis在预处理语句中设置一个参数时,或者从结果集中取出一个值时,都会用注册了的typeHader进行处理。typeHander的作用就是将参数从javaType转化为jdbcType,或者从数据库取出结果时把jdbcType转化为javaType。

系统内部已经定义了常用的类型处理器,有些情况下,需要自定义。

MyBatis也提供了枚举类型的类型处理器,有2个转化枚举类型的typeHandler,EnumTypeHandler和EnumOrdinalTypeHandler,其中EnumTypeHandler是使用枚举字符串名称作为参数传递的,EnumOrdinalTypeHandler是使用整数下标作为参数传递的。

但这2个枚举类型应用不那么广泛,更多的时候,需要自定义typeHandler进行处理。

自定义类型处理器,首先要定义类型处理类,实现TypeHandler泛型接口:

public class SexEnumTypeHandler implements TypeHandler<Sex> {

    @Override
    public void setParameter(PreparedStatement ps, int i, Sex sex, JdbcType jdbcType) throws SQLException {
        ps.setInt(i, sex.getId());
    }

    @Override
    public Sex getResult(ResultSet rs, String name) throws SQLException {
        return Sex.getSex(rs.getInt(name));
    }

    @Override
    public Sex getResult(ResultSet rs, int id) throws SQLException {
        return Sex.getSex(id);
    }

    @Override
    public Sex getResult(CallableStatement cs, int id) throws SQLException {
        return Sex.getSex(cs.getInt(id));
    }
}

然后注册自定义的TypeHandler

<typeHandlers>
   <typeHandler handler="com.qqdong.study.SexEnumTypeHandler" javaType="sex"/>
</typeHandlers>

最后,在定义映射器时,指定typeHandler即可

<select id="getUser" parameterType="long" resultType="userMap">
</select>

<resultMap id="userMap" type="user">
    <result column="sex" property="sex" typeHandler="com.qqdong.study.SexEnumTypeHandler">
</resultMap>

ObjectFactory

当MyBatis在构建一个结果返回的时候,都会使用ObjectFactory去构建POJO,在MyBatis中可以定制自己的对象工厂。一般不用配置,使用默认的DefaultObjectFactory即可。

插件plugin

插件比较复杂,后续单独一篇文章介绍。

environments配置环境

配置环境可以注册多个数据源,每个数据源包括基本配置和数据库事务配置。

<environments default="development">
    <environment id="development">
    <!-- 采用jdbc事务管理 -->
        <transactionManager type="JDBC">
            <property name="autoCommit" value="false">
        </transactionManager>
        <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>

其中,transactionManager指定数据库事务,有3种配置方法:

  • JDBC,采用JDBC方式管理事务,在独立编码中常常使用;
  • MANAGED,采用容器方式管理事务,在JNDI数据源中常用;
  • 自定义,由使用者自定义数据库事务管理方法;

dataSource标签,配置数据源连接信息,type配置对数据库连接方式,有以下几种:

  • UNPOOLED:非连接池数据库;
  • POOLED:连接池数据库;
  • JNDI:JNDI数据源;
  • 自定义数据源;

databaseIdProvider数据库厂商标识

该属性的作用在于指定SQL到对应的数据库厂商提供的数据库中运行。不常用,就不介绍了。

映射器

映射器是MyBatis最复杂、最核心的配置,包括参数类型、动态SQL、定义SQL、缓存信息等功能,上篇文章也演示了具体的例子,下篇文章会重点介绍细节。

欢迎扫描下方二维码,关注我的个人微信公众号 ~

情情说

1
0
分享到:
评论

相关推荐

    深入浅出Mybatis技术原理与实战-高清pdf

    《深入浅出Mybatis技术原理与实战》这本书旨在帮助读者全面理解MyBatis的内部工作机制,并通过实例演练提升实际开发技能。 首先,我们要了解MyBatis的核心概念。MyBatis是一个基于Java的持久层框架,它简化了数据库...

    《深入浅出MyBatis技术原理与实战》高清完整PDF下载

    本书详细介绍了MyBatis的基础组成、配置、映射器、动态SQL,教会读者正确使用MyBatis,书中包含大量的实例,使读者可以参考。接着介绍了MyBatis的运行原理和插件开发并配有一个完整的插件例子。为了增加实用性,作者...

    电子书-深入浅出Mybatis技术原理与实战

    《深入浅出Mybatis技术原理与实战》这本书是针对Mybatis这一流行持久层框架的一份详尽指南。Mybatis是一个优秀的Java ORM(对象关系映射)框架,它允许开发者将数据库操作与应用程序逻辑分离,提高了代码的可读性...

    深入浅出MyBatis技术原理与实战 源代码

    "深入浅出MyBatis技术原理与实战"这本书旨在帮助读者理解MyBatis的核心概念,并通过实战演练提升其在实际项目中的应用能力。第二章的源代码主要涵盖了MyBatis的基本配置、动态SQL以及Mapper接口的使用等关键知识点。...

    深入浅出MyBatis技术原理与实战

    《深入浅出MyBatis技术原理与实战》这本书旨在帮助读者全面理解MyBatis这一流行的Java持久层框架,深入解析其工作原理,并提供实战指导。MyBatis是一个轻量级的ORM(对象关系映射)框架,它允许开发者将SQL语句与...

    深入浅出MyBatis技术原理与实战.pdf.7z

    《深入浅出MyBatis技术原理与实战》是一本针对Java开发者深度解析MyBatis框架的书籍,旨在帮助读者理解MyBatis的核心概念、工作原理,并通过实战演练提升其在实际项目中的应用能力。该书内容涵盖了MyBatis与Spring、...

    深入浅出MyBatis技术原理与实战.杨开振(详细书签)

    总的来说,《深入浅出MyBatis技术原理与实战》会深入讲解MyBatis的各个方面,包括基本原理、配置、SQL映射、结果映射、事务管理、动态SQL、缓存机制以及实战应用。通过阅读本书,读者不仅可以了解MyBatis的全貌,还...

    深入浅出 mybatis技术原理与实践pdf

    《深入浅出 MyBatis 技术原理与实践》是一本专为 Java 开发者深入理解 MyBatis 框架而编写的书籍。MyBatis 是一款深受开发者喜爱的持久层框架,它允许程序员将 SQL 语句与 Java 代码紧密集成,从而简化了数据访问层...

    深入浅出MyBatis技术原理与实战.pdf

    通过《深入浅出MyBatis技术原理与实战》这本书,读者可以系统学习MyBatis的各个方面,包括基础概念、核心组件、映射机制、事务管理、缓存策略,以及在实际项目中的应用技巧,从而成为一名熟练掌握MyBatis的开发者。

    杨开振的深入浅出myBatis技术原理与实战的pdf版本.rar

    《深入浅出myBatis技术原理与实战》是由著名IT专家杨开振撰写的一本关于Mybatis技术的专著,这本书旨在帮助初中级开发者全面理解并掌握Mybatis框架的运用和核心原理。Mybatis作为一款广泛应用的Java持久层框架,以其...

    深入浅出MyBatis技术原理与实战(高清带书签)

    《深入浅出MyBatis技术原理与实战》是一本针对Java开发者深度解析MyBatis框架的专业书籍。MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射,旨在简化Java开发中的数据库操作。这本书通过理论...

    深入浅出MyBatis技术原理与实战(高清目录+部份源码)

    《深入浅出MyBatis技术原理与实战》是一本针对Java开发者深度解析MyBatis框架的专业书籍。MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射,旨在简化Java开发中的数据库操作。这本书通过高清...

    高清深入浅出MyBatis技术原理与实战(超清晰)

    《高清深入浅出MyBatis技术原理与实战》是一本深度剖析MyBatis框架的书籍,旨在帮助读者全面理解MyBatis的使用方法、优化策略以及底层架构。这本书覆盖了从基础到高级的各种主题,适合不同层次的开发人员学习。 ...

    深入浅出MyBatis技术原理与实战 第六章 源代码

    在深入探讨MyBatis技术原理与实战的第六章中,我们主要关注的是MyBatis的源代码分析。MyBatis是一个流行的Java持久层框架,它提供了灵活的SQL映射功能,使得开发人员能够轻松地将数据库操作与业务逻辑集成在一起。这...

    (高清+目录)深入浅出MyBatis技术原理与实战.zip

    本书详细介绍了MyBatis的基础组成、配置、映射器、动态SQL,教会读者正确使用MyBatis,书中包含大量的实例,使读者可以参考。接着介绍了MyBatis的运行原理和插件开发并配有一个完整的插件例子。为了增加实用性,作者...

Global site tag (gtag.js) - Google Analytics