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

来源:互联网 发布:chrome测试javascript 编辑:程序博客网 时间:2024/05/21 22:58

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.Driverjdbc.url=jdbc:mysql://localhost:3306/shiro?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertTonulljdbc.username=rootjdbc.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 | falseTRUE lazyLoadingEnabled在全局范围内启用或禁用延迟加载。禁用时,所有协会将热加载。true | falseTRUE aggressiveLazyLoading启用时,有延迟加载属性的对象将被完全加载后调用懒惰的任何属性。否则,每一个属性是按需加载。true | falseTRUE multipleResultSetsEnabled允许或不允许从一个单独的语句(需要兼容的驱动程序)要返回多个结果集。true | falseTRUE useColumnLabel使用列标签,而不是列名。在这方面,不同的驱动有不同的行为。参考驱动文档或测试两种方法来决定你的驱动程序的行为如何。true | falseTRUE useGeneratedKeys允许JDBC支持生成的密钥。兼容的驱动程序是必需的。此设置强制生成的键被使用,如果设置为true,一些驱动会不兼容性,但仍然可以工作。true | falseFALSE autoMappingBehavior指定MyBatis的应如何自动映射列到字段/属性。NONE自动映射。 PARTIAL只会自动映射结果没有嵌套结果映射定义里面。 FULL会自动映射的结果映射任何复杂的(包含嵌套或其他)。NONE, PARTIAL, FULLPARTIAL defaultExecutorType配置默认执行人。SIMPLE执行人确实没有什么特别的。 REUSE执行器重用准备好的语句。 BATCH执行器重用语句和批处理更新。SIMPLE REUSE BATCHSIMPLE defaultStatementTimeout设置驱动程序等待一个数据库响应的秒数。Any positive integerNot Set (null) safeRowBoundsEnabled允许使用嵌套的语句RowBoundstrue | falseFALSE mapUnderscoreToCamelCase从经典的数据库列名A_COLUMN启用自动映射到骆驼标识的经典的Java属性名aColumntrue | falseFALSE localCacheScopeMyBatis的使用本地缓存,以防止循环引用,并加快反复嵌套查询。默认情况下(SESSION)会话期间执行的所有查询缓存。如果localCacheScope=STATMENT本地会话将被用于语句的执行,只是没有将数据共享之间的两个不同的调用相同的SqlSessionSESSION | STATEMENTSESSION dbcTypeForNull指定为空值时,没有特定的JDBC类型的参数的JDBC类型。有些驱动需要指定列的JDBC类型,但其他像NULLVARCHAROTHER的工作与通用值。JdbcType enumeration. Most common are: NULL, VARCHAR and OTHEROTHER lazyLoadTriggerMethods指定触发延迟加载的对象的方法。A method name list separated by commasequals,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初始化。注意原语(如整型,布尔等)不会被设置为nulltrue | falseFALSE logPrefix指定的前缀字串,MyBatis将会增加记录器的名称。Any StringNot set logImpl指定MyBatis的日志实现使用。如果此设置是不存在的记录的实施将自动查找。SLF4J | LOG4J | LOG4J2 | JDK_LOGGING | COMMONS_LOGGING | STDOUT_LOGGING | NO_LOGGINGNot 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



                                             
0 0