您的位置:首页 > 其它

mybatis学习总结-核心配置文件mybatis-config.xml(一)

2016-11-03 00:28 701 查看
转自

作者:yuchaopeng

之前完成了一个mybatis的CRUD操作进行了最基本的体验。

回顾一下mybatis的步骤:

1)核心配置文件配置

2)pojo模型创建

3)映射文件配置

4)获取SqlSessionFactory

5)获取SqlSession

6)CRUD操作

7)事务操作

8)关闭SqlSession

mybatis的基本操作在这里:

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过来的 )

//表格暂时略

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.Boolean, boolean任何兼容的布尔值
ByteTypeHandlerjava.lang.Byte, byte任何兼容的数字或字节类型
ShortTypeHandlerjava.lang.Short, short任何兼容的数字或短整型
IntegerTypeHandlerjava.lang.Integer, int任何兼容的数字和整型
LongTypeHandlerjava.lang.Long, long任何兼容的数字或长整型
FloatTypeHandlerjava.lang.Float, float任何兼容的数字或单精度浮点型
DoubleTypeHandlerjava.lang.Double, double任何兼容的数字或双精度浮点型
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).
关于自定义类型处理器,会单独做一个总结。

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的一些基本配置。

还没有总结完,比如environments和其他的配置,下一篇文章专门说明environments和剩下的配置
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: