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的配置:
而一般情况下,对于这种配置信息,一般我们都会把它放到properties资源文件中。
1.创建一个资源文件jdbc.properties:
2.mybatis-config.xml中引入
当然也可以在标签中定义属性:
3.使用properties文件里的属性
说下这些配置的加载顺序:
在 properties 元素体内指定的属性首先被读取。
从类路径下资源或 properties 元素的 url 属性中加载的属性第二被读取,它会 覆盖已经存在的完全一样的属性。
作为方法参数传递的属性最后被读取, 它也会覆盖任一已经存在的完全一样的 属性,这些属性可能是从 properties 元素体内和资源/url 属性中加载的。
引用自:http://mybatis.github.io/mybatis-3/zh/configuration.html
所以,属性的优先级为:方法直接传递参数 > 通过resource、url引用的资源 > properties元素体内定义
配置方式:
配置项说明:(从 http://mybatis.github.io/mybatis-3/zh/configuration.html copy过来的 )
//表格暂时略
在mybatis初体验(一)中的UserMapper.xml配置中,有这样的配置信息:
可以看到resultType属性的值为com.yu.model.User,表示这个查询返回的类型为com.yu.model.User类型。
如果有很多种类型的话,每次都得把类型的全路径写上,感觉就很费事。
所以就可以用mybatis提供的typeAliases来进行别名配置。
在核心配置文件中加上配置:
然后修改UserMapper.xml的配置:
这样就简便多了。
当然,这是对于我们自定义的类型,或者其他类型,用这种设置别名的方式。
其实mybatis给我们提供了很多内建的类型别名,使我们不用在typeAliases中指定,就可以直接使用,下面是mybatis中内建的别名:
1. 获取数据库的值,以合适的方式转变为对应的java类型。
2. 将java类型,以合适的方式转化为数据库的保存类型。
mybatis中默认的类型处理器:
关于自定义类型处理器,会单独做一个总结。
用于引用定义好的映射定义,告诉mybatis去哪里找我们的sql定义配置。有以下几种用法:
直接引用xml文件
通过绝对路径引用,注意在绝对路径前加上:“file:///”
引用mapper接口对象的方式:
引用mapper接口包的方式:
这篇文章介绍了mybatis核心配置文件mybatis-config.xml的一些基本配置。
还没有总结完,比如environments和其他的配置,下一篇文章专门说明environments和剩下的配置
作者: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中内建的别名:
别名 | 映射的类型 |
---|---|
_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 |
object | Object |
map | Map |
hashmap | HashMap |
list | List |
arraylist | ArrayList |
collection | Collection |
iterator | Iterator |
typeHandlers
类型处理器,用途:1. 获取数据库的值,以合适的方式转变为对应的java类型。
2. 将java类型,以合适的方式转化为数据库的保存类型。
mybatis中默认的类型处理器:
类型处理器 | Java类型 | JDBC 类型 |
---|---|---|
BooleanTypeHandler | java.lang.Boolean, boolean | 任何兼容的布尔值 |
ByteTypeHandler | java.lang.Byte, byte | 任何兼容的数字或字节类型 |
ShortTypeHandler | java.lang.Short, short | 任何兼容的数字或短整型 |
IntegerTypeHandler | java.lang.Integer, int | 任何兼容的数字和整型 |
LongTypeHandler | java.lang.Long, long | 任何兼容的数字或长整型 |
FloatTypeHandler | java.lang.Float, float | 任何兼容的数字或单精度浮点型 |
DoubleTypeHandler | java.lang.Double, double | 任何兼容的数字或双精度浮点型 |
BigDecimalTypeHandler | java.math.BigDecimal | 任何兼容的数字或十进制小数类型 |
StringTypeHandler | java.lang.String | CHAR 和VARCHAR 类型 |
ClobTypeHandler | java.lang.String | CLOB 和 LONGVARCHAR 类型 |
NStringTypeHandler | java.lang.String | NVARCHAR 和 NCHAR 类型 |
NClobTypeHandler | java.lang.String | NCLOB 类型 |
ByteArrayTypeHandler | byte[] | 任何兼容的字节流类型 |
BlobTypeHandler | byte[] | BLOB和LONGVARBINARY 类型 |
DateTypeHandler | java.util.Date | TIMESTAMP 类型 |
DateOnlyTypeHandler | java.util.Date | DATE 类型 |
TimeOnlyTypeHandler | java.util.Date | TIME 类型 |
SqlTimestampTypeHandler | java.sql.Timestamp | TIMESTAMP 类型 |
SqlDateTypeHandler | java.sql.Date | DATE 类型 |
SqlTimeTypeHandler | java.sql.Time | TIME 类型 |
ObjectTypeHandler | Any | 其他或未指定类型 |
EnumTypeHandler | Enumeration Type | VARCHAR-任何兼容的字符串类型, 作为代码存储(而不是索引) |
EnumOrdinalTypeHandler | Enumeration Type | Any 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和剩下的配置
相关文章推荐
- mybatis学习总结-核心配置文件mybatis-config.xml(一)
- mybatis学习总结-核心配置文件mybatis-config.xml(二)
- mybatis学习总结-核心配置文件mybatis-config.xml(一)
- mybatis学习总结-核心配置文件mybatis-config.xml(二)
- mybatis学习总结-核心配置文件mybatis-config.xml(一)
- mybatis学习总结-核心配置文件mybatis-config.xml(二)
- mybatis学习总结-核心配置文件mybatis-config.xml(一)
- Mybatis学习总结(三)——SqlMapConfig.xml全局配置文件解析
- 【MyBatis学习05】SqlMapConfig.xml文件中的配置总结
- 【MyBatis学习05】SqlMapConfig.xml文件中的配置总结
- 【MyBatis学习05】SqlMapConfig.xml文件中的配置总结
- 【MyBatis学习05】SqlMapConfig.xml文件中的配置总结
- 【MyBatis学习05】SqlMapConfig.xml文件中的配置总结
- 【MyBatis学习05】SqlMapConfig.xml文件中的配置总结
- MyBatis学习(二)-XML映射配置文件mybatis-config.xml
- solr全文检索技术学习(一)-核心配置文件solrconfig.xml
- SqlMapConfig.xml配置文件---Mybatis学习笔记(七)
- mybatis源码学习之执行过程分析(2)——config.xml配置文件和mapper.xml映射文件解析过程
- Mybatis学习(3)关于mybatis全局配置文件SqlMapConfig.xml
- MyBatis基础学习:XML配置文件(mybatis/mybatis-config.xml)