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

mybatis-config.xml的配置:

  
  
  
      
      
          
              
              
                  
                  
                  
                  
              
          
      
      
      
      
          
      

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中引入


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


	

3.使用properties文件里的属性

  
        
        
        
         

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

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

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

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

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

配置方式:

  
          
          
          
          
          
          
          
          
          
          
          
          
          
    

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

设置参数 描述 有效值 默认值
cacheEnabled 这个配置使全局的映射器启用或禁用 缓存。 true | false true
lazyLoadingEnabled 全局启用或禁用延迟加载。当禁用时, 所有关联对象都会即时加载。 通过 在其上使用fetchType属性,可以取代特定关系的值 。 true | false false
aggressiveLazyLoading 当启用时, 有延迟加载属性的对象在被 调用时将会完全加载任意属性。否则, 每种属性将会按需要加载。 true | false true
multipleResultSetsEnabled 允许或不允许多种结果集从一个单独 的语句中返回(需要适合的驱动) true | false true
useColumnLabel 使用列标签代替列名。 不同的驱动在这 方便表现不同。 参考驱动文档或充分测 试两种方法来决定所使用的驱动。 true | false true
useGeneratedKeys 允许 JDBC 支持生成的键。 需要适合的 驱动。 如果设置为 true 则这个设置强制 生成的键被使用, 尽管一些驱动拒绝兼 容但仍然有效(比如 Derby) true | false False
autoMappingBehavior 指定 MyBatis 如何自动映射列到字段/ 属性。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 = STATEMENT本地会话将仅用于语句执行,则不会在对同一SqlSession的两个不同调用之间共享数据。 SESSION | STATEMENT SESSION
jdbcTypeForNull 如果未为参数提供特定的JDBC类型,则指定空值的JDBC类型。某些驱动程序需要指定列JDBC类型,但其他驱动程序使用泛型值,如NULL,VARCHAR或OTHER。 JdbcType 枚举. 最常见的: NULL, VARCHAR 和 OTHER OTHER
lazyLoadTriggerMethods 指定哪个Object的方法触发延迟加载 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 当结果集中含有Null值时是否执行映射对象的setter或者Map对象的put方法。此设置对于原始类型如int,boolean等无效。 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 CGLIB

typeAliases

类型别名。

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

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


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

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

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

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

  
      
      

然后修改UserMapper.xml的配置:


这样就简便多了。

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

其实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.Booleanboolean 任何兼容的布尔值
ByteTypeHandler java.lang.Bytebyte 任何兼容的数字或字节类型
ShortTypeHandler java.lang.Shortshort 任何兼容的数字或短整型
IntegerTypeHandler java.lang.Integerint 任何兼容的数字和整型
LongTypeHandler java.lang.Longlong 任何兼容的数字或长整型
FloatTypeHandler java.lang.Floatfloat 任何兼容的数字或单精度浮点型
DoubleTypeHandler java.lang.Doubledouble 任何兼容的数字或双精度浮点型
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).

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

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

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

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

mappers

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

  
   
       
 

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

直接引用xml文件

  
       

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

  
      

引用mapper接口对象的方式:

  
       

引用mapper接口包的方式:

  
     

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

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

你可能感兴趣的:(MyBatis核心配置文件mybatis-config.xml的配置方法)