MyBatis核心配置文件mybatis-config.xml的配置方法

mybatis-config.xml的配置:

<?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE configuration  
  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"  
  "http://mybatis.org/dtd/mybatis-3-config.dtd">  
<configuration>  
    <!-- 对事务的管理和连接池的配置 -->  
    <environments default="development">  
        <environment id="development">  
            <transactionManager type="JDBC" />  
            <dataSource type="POOLED">  
                <property name="driver" value="oracle.jdbc.driver.OracleDriver" />  
                <property name="url" value="jdbc:oracle:thin:@localhost:1521:orcl" />  
                <property name="username" value="ibatis" />  
                <property name="password" value="ibatis" />  
            </dataSource>  
        </environment>  
    </environments>  
      
    <!-- mapping 文件路径配置 -->  
    <mappers>  
        <mapper resource="com/yu/res/UserMapper.xml" />  
    </mappers>  
</configuration>

Properties
由上面的配置可以看出,我们的数据库信息是直接写到了配置里

而一般情况下,对于这种配置信息,一般我们都会把它放到properties资源文件中。

1.创建一个资源文件jdbc.properties:

jdbc.driverClassName=oracle.jdbc.driver.OracleDriver
jdbc.url=jdbc:oracle:thin:@localhost:1521:orcl
jdbc.username=mybatis  
jdbc.password=mybatis

2.mybatis-config.xml中引入

<properties resource="jdbc.properties" />

当然也可以在标签中定义属性:

<properties resource="jdbc.properties">
	<property name="jdbc.driverClassName" value="oracle.jdbc.driver.OracleDriver"/>
</properties>

3.使用properties文件里的属性

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

说下这些配置的加载顺序:

.在 properties 元素体内指定的属性首先被读取。 .从类路径下资源或 properties 元素的 url
属性中加载的属性第二被读取,它会 覆盖已经存在的完全一样的属性。 .作为方法参数传递的属性最后被读取, 它也会覆盖任一已经存在的完全一样的属性,这些属性可能是从 properties 元素体内和资源/url 属性中加载的。

引用自:http://mybatis.github.io/mybatis-3/zh/configuration.html

所以,属性的优先级为:方法直接传递参数 > 通过resource、url引用的资源 > properties元素体内定义

Settings
setting设置,关系到mybatis的主要设置,关系到mybatis运行时的行为方式。

配置方式:

<settings>  
        <setting name="cacheEnabled" value="true" />  
        <setting name="lazyLoadingEnabled" value="true" />  
        <setting name="multipleResultSetsEnabled" value="true" />  
        <setting name="useColumnLabel" value="true" />  
        <setting name="useGeneratedKeys" value="false" />  
        <setting name="autoMappingBehavior" value="PARTIAL" />  
        <setting name="defaultExecutorType" value="SIMPLE" />  
        <setting name="defaultStatementTimeout" value="25" />  
        <setting name="safeRowBoundsEnabled" value="false" />  
        <setting name="mapUnderscoreToCamelCase" value="false" />  
        <setting name="localCacheScope" value="SESSION" />  
        <setting name="jdbcTypeForNull" value="OTHER" />  
        <setting name="lazyLoadTriggerMethods" value="equals,clone,hashCode,toString" />  
    </settings>

配置项说明:(从 http://mybatis.github.io/mybatis-3/zh/configuration.html copy过来的 )

设置参数描述有效值默认值
cacheEnabled这个配置使全局的映射器启用或禁用 缓存。true | falsetrue
lazyLoadingEnabled全局启用或禁用延迟加载。当禁用时, 所有关联对象都会即时加载。 通过 在其上使用fetchType属性,可以取代特定关系的值 。true | falsefalse
aggressiveLazyLoading当启用时, 有延迟加载属性的对象在被 调用时将会完全加载任意属性。否则, 每种属性将会按需要加载。true | falsetrue
multipleResultSetsEnabled允许或不允许多种结果集从一个单独 的语句中返回(需要适合的驱动)true | falsetrue
useColumnLabel使用列标签代替列名。 不同的驱动在这 方便表现不同。 参考驱动文档或充分测 试两种方法来决定所使用的驱动。true | falsetrue
useGeneratedKeys允许 JDBC 支持生成的键。 需要适合的 驱动。 如果设置为 true 则这个设置强制 生成的键被使用, 尽管一些驱动拒绝兼 容但仍然有效(比如 Derby)true | falseFalse
autoMappingBehavior指定 MyBatis 如何自动映射列到字段/ 属性。PARTIAL 只会自动映射简单, 没有嵌套的结果。FULL 会自动映射任 意复杂的结果(嵌套的或其他情况) 。NONE, PARTIAL, FULLPARTIAL
defaultExecutorType配置默认的执行器。SIMPLE 执行器没 有什么特别之处。REUSE 执行器重用 预处理语句。BATCH 执行器重用语句 和批量更新SIMPLE REUSE BATCHSIMPLE
defaultStatementTimeout设置超时时间, 它决定驱动等待一个数 据库响应的时间。Any positive integerNot Set (null)
safeRowBoundsEnabled允许在嵌套语句上使用RowBounds。true | falseFalse
mapUnderscoreToCamelCase启用从经典数据库列名A_COLUMN到驼峰式经典Java属性名称aColumn的自动映射。true | falseFalse
localCacheScopeMyBatis使用本地缓存来防止循环引用并加速重复的嵌套查询。默认情况下(SESSION)会话期间执行的所有查询都将被缓存。如果localCacheScope = STATEMENT本地会话将仅用于语句执行,则不会在对同一SqlSession的两个不同调用之间共享数据。SESSION | STATEMENTSESSION
jdbcTypeForNull如果未为参数提供特定的JDBC类型,则指定空值的JDBC类型。某些驱动程序需要指定列JDBC类型,但其他驱动程序使用泛型值,如NULL,VARCHAR或OTHER。JdbcType 枚举. 最常见的: NULL, VARCHAR 和 OTHEROTHER
lazyLoadTriggerMethods指定哪个Object的方法触发延迟加载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当结果集中含有Null值时是否执行映射对象的setter或者Map对象的put方法。此设置对于原始类型如int,boolean等无效。true | falsefalse
logPrefix指定MyBatis将添加到记录器名称的前缀字符串。Any StringNot set
logImpl 指定MyBatis应使用的日志记录实现。如果此设置不存在,则会自动发现日志记录实现SLF4J | LOG4J | LOG4J2 | JDK_LOGGING | COMMONS_LOGGING | STDOUT_LOGGING | NO_LOGGINGNot set
proxyFactory指定MyBatis将用于创建延迟加载功能对象的代理工具。CGLIB | JAVASSISTCGLIB

typeAliases

类型别名。

给java类型取一个别名,方便在核心配置、映射配置中来使用这个java类型。

在 mybatis初体验(一) 中的UserMapper.xml配置中,有这样的配置信息:

<select id="findUserById" resultType="com.yu.model.User" parameterType="long">  
        select * from t_user where id = #{id}
</select>

可以看到resultType属性的值为com.yu.model.User,表示这个查询返回的类型为com.yu.model.User类型。

如果有很多种类型的话,每次都得把类型的全路径写上,感觉就很费事。

所以就可以用mybatis提供的typeAliases来进行别名配置。

在核心配置文件中加上配置:

<typeAliases>  
      <typeAlias type="com.yu.model.User" alias="User" />
      <typeAlias type="com.yu.model.Org" alias="Org"/>
</typeAliases>

然后修改UserMapper.xml的配置:

<select id="findUserById" resultType="User" parameterType="long">  
        select * from t_user where id = #{id}
</select>

这样就简便多了。

当然,这是对于我们自定义的类型,或者其他类型,用这种设置别名的方式。

其实mybatis给我们提供了很多内建的类型别名,使我们不用在typeAliases中指定,就可以直接使用,下面是mybatis中内建的别名:

别名映射的类型
_bytebyte
_longlong
_shortshort
_intint
_integerint
_doubledouble
_floatfloat
_booleanboolean
stringString
byteByte
longLong
shortShort
intInteger
integerInteger
doubleDouble
floatFloat
booleanBoolean
dateDate
decimalBigDecimal
bigdecimalBigDecimal
objectObject
mapMap
hashmapHashMap
listList
arraylistArrayList
collectionCollection
iteratorIterator

typeHandlers

类型处理器。

用途:

1)获取数据库的值,以合适的方式转变为对应的java类型

2)将java类型,以合适的方式转化为数据库的保存类型

mybatis中默认的类型处理器:

类型处理器Java 类型JDBC 类型
BooleanTypeHandlerjava.lang.Booleanboolean任何兼容的布尔值
ByteTypeHandlerjava.lang.Bytebyte任何兼容的数字或字节类型
ShortTypeHandlerjava.lang.Shortshort任何兼容的数字或短整型
IntegerTypeHandlerjava.lang.Integerint任何兼容的数字和整型
LongTypeHandlerjava.lang.Longlong任何兼容的数字或长整型
FloatTypeHandlerjava.lang.Floatfloat任何兼容的数字或单精度浮点型
DoubleTypeHandlerjava.lang.Doubledouble任何兼容的数字或双精度浮点型
BigDecimalTypeHandlerjava.math.BigDecimal任何兼容的数字或十进制小数类型
StringTypeHandlerjava.lang.StringCHAR 和 VARCHAR 类型
ClobTypeHandlerjava.lang.StringCLOB 和 LONGVARCHAR 类型
NStringTypeHandlerjava.lang.StringNVARCHAR 和 NCHAR 类型
NClobTypeHandlerjava.lang.StringNCLOB 类型
ByteArrayTypeHandlerbyte[]任何兼容的字节流类型
BlobTypeHandlerbyte[]BLOB 和 LONGVARBINARY 类型
DateTypeHandlerjava.util.DateTIMESTAMP 类型
DateOnlyTypeHandlerjava.util.DateDATE 类型
TimeOnlyTypeHandlerjava.util.DateTIME 类型
SqlTimestampTypeHandlerjava.sql.TimestampTIMESTAMP 类型
SqlDateTypeHandlerjava.sql.DateDATE 类型
SqlTimeTypeHandlerjava.sql.TimeTIME 类型
ObjectTypeHandlerAny其他或未指定类型
EnumTypeHandlerEnumeration TypeVARCHAR-任何兼容的字符串类型, 作为代码存储(而不是索引)
EnumOrdinalTypeHandlerEnumeration TypeAny compatible NUMERIC or DOUBLE, as the position is stored (not the code itself).

当然也可以自定义类型处理器,

比如有一个字段的值是一个逗号隔开的字符串,如果希望查询结果映射到java类型时是一个数组,而保存到数据库时又会是以逗号隔开的字符串。

这种情况需要自定义类型处理器来处理。

关于自定义类型处理器,会单独做一个总结。

mappers

在 mybatis初体验(一) 中的UserMapper.xml配置中,有这样的配置信息:

<!-- mapping 文件路径配置 -->  
 <mappers>  
     <mapper resource="com/yu/res/UserMapper.xml" />  
 </mappers>

用于引用定义好的映射定义,告诉mybatis去哪里找我们的sql定义配置。有以下几种用法:

直接引用xml文件

<mappers>  
     <mapper resource="com/yu/res/UserMapper.xml" />  
</mappers>

通过绝对路径引用,注意在绝对路径前加上:“file:///”

<mappers>  
     <mapper url="file:///D:/workspace/mywork/MyBatis/src/com/yu/res/UserMapper.xml"/> 
</mappers>

引用mapper接口对象的方式:

<mappers>  
     <mapper resource="com.yu.mapper.UserMapper" />  
</mappers>

引用mapper接口包的方式:

<mappers>  
     <package name="com.yu.mapper"/>
</mappers>

这篇文章介绍了mybatis核心配置文件mybatis-config.xml的一些基本配置。

作者:yu博客
积一时之硅步,臻千里之遥程。
原文地址:mybatis学习总结-核心配置文件mybatis-config.xml(一), 感谢原作者分享。

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值