mybatis学习教程(四)全局设置简略mybatis-config.xml


1、前言

本文简略讲解一下properties的文件定义,与全局变量的定义,以及别名的定义。

2、propertiese文件定位

 可以把一些通用的属性值配置在属性文件中,加载到mybatis运行环境内。

比如:创建db.properties配置数据库连接参数。

sqlconfig的修改

<pre name="code" class="html"><!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!--配置属性值,可以在属性文件内编写属性值,也可以在properties标签里面写属性值-->
    <properties resource="config/db.properties">
      <!--  <property name="" value=""></property>-->
    </properties>
    <!--与spring整个后环境配置将废除-->
    <environments default="development">
        <environment id="development">
            <!--使用JDBC事务管理-->
            <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>
    <!--加载mapper-->
    <mappers>
        <mapper  resource="mapper/UserMapper.xml"/>
    </mappers>
</configuration>




db.properties文件
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/shiro?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertTonull
jdbc.username=root
jdbc.password=123456

2.1注意properties文件的一些定义

MyBatis 将按照下面的顺序来加载属性:

1】在 properties 元素体内定义的属性首先被读取。 

2】然后会读取properties 元素中resource或 url 加载的属性,它会覆盖已读取的同名属性。 

3】最后读取parameterType传递的属性,它会覆盖已读取的同名属性。

建议使用properties,不要在properties中定义属性,只引用定义的properties文件中属性,并且properties文件中定义的key要有一些特殊的规则。

3、mybatis全局属性设置


Setting(设置) Description(描述) Valid Values(验证值组) Default(默认值)  
cacheEnabled 在全局范围内启用或禁用缓存配置任何映射器在此配置下。 true | false TRUE  
lazyLoadingEnabled 在全局范围内启用或禁用延迟加载。禁用时,所有协会将热加载。 true | false TRUE  
aggressiveLazyLoading 启用时,有延迟加载属性的对象将被完全加载后调用懒惰的任何属性。否则,每一个属性是按需加载。 true | false TRUE  
multipleResultSetsEnabled 允许或不允许从一个单独的语句(需要兼容的驱动程序)要返回多个结果集。 true | false TRUE  
useColumnLabel 使用列标签,而不是列名。在这方面,不同的驱动有不同的行为。参考驱动文档或测试两种方法来决定你的驱动程序的行为如何。 true | false TRUE  
useGeneratedKeys 允许JDBC支持生成的密钥。兼容的驱动程序是必需的。此设置强制生成的键被使用,如果设置为true,一些驱动会不兼容性,但仍然可以工作。 true | false FALSE  
autoMappingBehavior 指定MyBatis的应如何自动映射列到字段/属性。NONE自动映射。 PARTIAL只会自动映射结果没有嵌套结果映射定义里面。 FULL会自动映射的结果映射任何复杂的(包含嵌套或其他)。 NONE, PARTIAL, FULL PARTIAL  
defaultExecutorType 配置默认执行人。SIMPLE执行人确实没有什么特别的。 REUSE执行器重用准备好的语句。 BATCH执行器重用语句和批处理更新。 SIMPLE REUSE BATCH SIMPLE  
defaultStatementTimeout 设置驱动程序等待一个数据库响应的秒数。 Any positive integer Not Set (null)  
safeRowBoundsEnabled 允许使用嵌套的语句RowBounds true | false FALSE  
mapUnderscoreToCamelCase 从经典的数据库列名A_COLUMN启用自动映射到骆驼标识的经典的Java属性名aColumn true | false FALSE  
localCacheScope MyBatis的使用本地缓存,以防止循环引用,并加快反复嵌套查询。默认情况下(SESSION)会话期间执行的所有查询缓存。如果localCacheScope=STATMENT本地会话将被用于语句的执行,只是没有将数据共享之间的两个不同的调用相同的SqlSession SESSION | STATEMENT SESSION  
dbcTypeForNull 指定为空值时,没有特定的JDBC类型的参数的JDBC类型。有些驱动需要指定列的JDBC类型,但其他像NULLVARCHAROTHER的工作与通用值。 JdbcType enumeration. Most common are: NULL, VARCHAR and OTHER OTHER  
lazyLoadTriggerMethods 指定触发延迟加载的对象的方法。 A method name list separated by commas equals,clone,hashCode,toString  
defaultScriptingLanguage 指定所使用的语言默认为动态SQL生成。 A type alias or fully qualified class name. org.apache.ibatis.scripting.xmltags.XMLDynamicLanguageDriver  
callSettersOnNulls 指定如果setter方法​​或地图的put方法时,将调用检索到的值是null。它是有用的,当你依靠Map.keySet()或null初始化。注意原语(如整型,布尔等)不会被设置为null true | false FALSE  
logPrefix 指定的前缀字串,MyBatis将会增加记录器的名称。 Any String Not set  
logImpl 指定MyBatis的日志实现使用。如果此设置是不存在的记录的实施将自动查找。 SLF4J | LOG4J | LOG4J2 | JDK_LOGGING | COMMONS_LOGGING | STDOUT_LOGGING | NO_LOGGING Not set  
proxyFactory 指定代理工具,MyBatis将会使用创建懒加载能力的对象。 CGLIB | JAVASSIST    

4、别名的定义

       
4.1mybatis本身别名定义

别名

映射的类型

_byte 

byte 

_long 

long 

_short 

short 

_int 

int 

_integer 

int 

_double 

double 

_float 

float 

_boolean 

boolean 

string 

String 

byte 

Byte 

long 

Long 

short 

Short 

int 

Integer 

integer 

Integer 

double 

Double 

float 

Float 

boolean 

Boolean 

date 

Date 

decimal 

BigDecimal 

bigdecimal 

BigDecimal 

4.2自定义别名
typeAliases别名
sqlconfig定义文件如下:
package 可以使用多个

<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!--配置属性值,可以在属性文件内编写属性值,也可以在properties标签里面写属性值-->
    <properties resource="config/db.properties">
      <!--  <property name="" value=""></property>-->
    </properties>
    <typeAliases>
        <!--别名定义1:指定单个路径定义别名(不常用)-->
      <!--  <typeAlias type="com.ycy.mybatis.module.User" alias="User"/>-->
        <!--别名定义2:指定包路径,默认为类的名字(首字母大小写都可以,建议大写)-->
        <package name="com.ycy.mybatis.module" />
    </typeAliases>

    <!--与spring整个后环境配置将废除-->
    <environments default="development">
        <environment id="development">
            <!--使用JDBC事务管理-->
            <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>
    <!--加载mapper-->
    <mappers>
        <mapper  resource="mapper/UserMapper.xml"/>
    </mappers>
</configuration>

5、mapper配置

3种方式只选择一种,注意由于我用的idea,亲测只能用第一种方法,就是resource方式,不要问我为什么,任性。
提示:但是以后用spring了,有一个spring扫描。
  <!--加载mapper-->
    <mappers>
        <!--如果和spring整合,可以使用整合包的 mapper扫描器,此处mapper配置不需要;-->
        <!--1:通过resource路径导入xml映射(idea必须在resource文件下面)-->
        <mapper  resource="mapper/UserMapper.xml"/>
        <!--2:通过class路径导入映射,注意:此时class文件必须与想xml文件在一个目录下,同名-->
        <mapper class="com.ycy.mybatis.dao.UserMapper" />
        <!--3:通过批量导入package,自动扫描包下面mapper接口 注意:此时class文件必须与想xml文件在一个目录下,同名-->
        <package name="com.ycy.mybatis.dao"/>
    </mappers>

如有疑问:qq群:78275755(目前木有人,来啦更好)
本项目1-5章 初级教程 项目百度分享盘:
http://pan.baidu.com/s/1o63SUaI




                
上一篇:剑指Offer之二叉树的深度


下一篇:第四章 虚拟机类加载