MyBatis配置文件(mybatis-config.xml)
MyBatis 配置文件的结构如下。
database.properties 用于描述数据库连接的相关配置,例如数据库驱动、连接数据库的 url、数据库用户名、数据库密码等。<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis网站站点" rel="nofollow" />
<properties resource="mybatisDemo/resources/database.properties"/>
2. properties子元素配置
通过 properties 子元素 property 配置 username 和 password 变量,然后在 environments 节点中引用这些变量,代码如下。
<properties>
<property name="username" value="root"/>
<property name="password" value="root"/>
</properties>
在 environments 节点中引用 username 和 password 变量。
也可以不使用 properties 标签,直接将属性值写在 value 中。<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
settings标签
settings 标签用于配置 MyBatis 的运行时行为,它能深刻的影响 MyBatis 的底层运行,一般不需要大量配置,大部分情况下使用其默认值即可。settings 的配置项很多,但是真正用到的不会太多,我们把常用的配置项研究清楚就可以了。settings 配置项说明如下表所示(表中红色字体的配置项为常用配置项)。
配置项 | 作用 | 配置选项 | 默认值 |
|---|---|---|---|
| cacheEnabled | 该配置影响所有映射器中配置缓存的全局开关 | true|false | true |
| lazyLoadingEnabled | 延迟加载的全局开关。当开启时,所有关联对象都会延迟加载。在特定关联关系中可通过设置 fetchType 属性来覆盖该项的开关状态 | true|false | false |
| aggressiveLazyLoading | 当启用时,对任意延迟属性的调用会使带有延迟加载属性的对象完整加载;反之,每种属性将会按需加载 | true|false | 版本3.4.1 (不包含) 之前默认值为 true,之后为 false |
multipleResultSetsEnabled | 是否允许单一语句返回多结果集(需要兼容驱动) | true|false | true |
useColumnLabel | 使用列标签代替列名。不同的驱动会有不同的表现,具体可参考相关驱动文档或通过测试这两种不同的模式来观察所用驱动的结果 | true|false | true |
useGeneratedKeys | 允许JDBC 支持自动生成主键,需要驱动兼容。如果设置为 true,则这个设置强制使用自动生成主键,尽管一些驱动不能兼容但仍可正常工作(比如 Derby) | true|false | false |
| autoMappingBehavior | 指定 MyBatis 应如何自动映射列到字段或属性。 NONE 表示取消自动映射。 PARTIAL 表示只会自动映射,没有定义嵌套结果集和映射结果集。 FULL 会自动映射任意复杂的结果集(无论是否嵌套) | NONE、PARTIAL、FULL | PARTIAL |
autoMappingUnkno wnColumnBehavior | 指定自动映射当中未知列(或未知属性类型)时的行为。 默认是不处理,只有当日志级别达到 WARN 级别或者以下,才会显示相关日志,如果处理失败会抛出 SqlSessionException 异常 | NONE、WARNING、FAILING | NONE |
| defaultExecutorType | 配置默认的执行器。SIMPLE 是普通的执行器;REUSE 会重用预处理语句(prepared statements);BATCH 执行器将重用语句并执行批量更新 | SIMPLE、REUSE、BATCH | SIMPLE |
defaultStatementTimeout | 设置超时时间,它决定驱动等待数据库响应的秒数 | 任何正整数 | Not Set (null) |
defaultFetchSize | 设置数据库驱动程序默认返回的条数限制,此参数可以重新设置 | 任何正整数 | Not Set (null) |
safeRowBoundsEnabled | 允许在嵌套语句中使用分页(RowBounds)。如果允许,设置 false | true|false | false |
safeResultHandlerEnabled | 允许在嵌套语句中使用分页(ResultHandler)。如果允许,设置false | true|false | true |
| mapUnderscoreToCamelCase | 是否开启自动驼峰名规则映射,即从经典数据库列名 A_COLUMN 到经典 Java 属性名 aColumn 的类似映射 | true|false | false |
localCacheScope | MyBatis 利用本地缓存机制(Local Cache)防止循环引用(circular references)和加速联复嵌套査询。 默认值为 SESSION,这种情况下会缓存一个会话中执行的所有查询。若设置值为 STATEMENT,本地会话仅用在语句执行上,对相同 SqlScssion 的不同调用将不会共享数据 | SESSION|STATEMENT | SESSION |
jdbcTypeForNull | 当没有为参数提供特定的 JDBC 类型时,为空值指定 JDBC 类型。某些驱动需要指定列的 JDBC 类型,多数情况直接用一般类型即可,比如 NULL、VARCHAR 或 OTHER | NULL、VARCHAR、OTHER | OTHER |
lazyLoadTriggerMethods | 指定哪个对象的方法触发一次延迟加载 | — | equals、clone、hashCode、toString |
defaultScriptingLanguage | 指定动态 SQL 生成的默认语言 | — | org.apache.ibatis .script.ing.xmltags .XMLDynamicLanguageDriver |
callSettersOnNulls | 指定当结果集中值为 null 时,是否调用映射对象的 setter(map 对象时为 put)方法,这对于 Map.kcySet() 依赖或 null 值初始化时是有用的。注意,基本类型(int、boolean 等)不能设置成 null | true|false | false |
logPrefix | 指定 MyBatis 增加到日志名称的前缀 | 任何字符串 | Not set |
loglmpl | 指定 MyBatis 所用日志的具体实现,未指定时将自动査找 | SLF4J|LOG4J|LOG4J2|JDK_LOGGING |COMMONS_LOGGING |ST DOUT_LOGGING|NO_LOGGING | Not set |
proxyFactory | 指定 MyBatis 创建具有延迟加栽能力的对象所用到的代理工具 | CGLIB|JAVASSIST | JAVASSIST (MyBatis 版本为 3.3 及以上的) |
vfsImpl | 指定 VFS 的实现类 | 提供 VFS 类的全限定名,如果存在多个,可以使用逗号分隔 | Not set |
useActualParamName | 允许用方法参数中声明的实际名称引用参数。要使用此功能,项目必须被编译为 Java 8 参数的选择。(从版本 3.4.1 开始可以使用) | true|false | true |
下面给出一个全量的配置样例,如下所示。
<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="autoMappingUnknownColumnBehavior" value="WARNING"/>
<setting name="defaultExecutorType" value="SIMPLE"/>
<setting name="defaultStatementTimeout" value="25"/>
<setting name="defaultFetchSize" value="100"/>
<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>
typeAliases标签
为了不在任何地方都指定类的全限定名,我们可以使用 typeAliases 标签定义一个别名。例如,在 net.bianchengbang.po 包中有一个 Student 类,则该类的全限定名称为 net.bianchengbang.po.Student。使用 typeAliases 标签定义别名,这样就不用每次都书写类的全限定名称了,代码如下。
<typeAliases>
<typeAlias alias = "Student" type = "net.bianchengbang.po.Student"/>
</typeAliases>
如果需要对同一个包下的多个类定义别名,则可以定义为:
这样 MyBatis 将扫描 net.biancheng.po 包里面的类,将其个字母变为小写作为其别名,例如 Student 别名为 student,User 别名为 user。<typeAliases>
<package name="net.biancheng.po"/>
</typeAliases>
typeHandlers标签
typeHandlers 主要将获取的值理地转化为 Java 类型。在 typeHandler 中,分为 jdbcType 和 javaType,其中 jdbcType 用于定义数据库类型,而 javaType 用于定义 Java 类型,typeHandler 的作用就是承担 jdbcType 和 javaType 之间的相互转换。MyBatis 支持自定义处理类型,在自定义处理类型时,需要实现 org.apache.ibatis.type.TypeHandler 接口或继承 org.apache.ibatis.type.BaseTypeHandle 类。详细可参考官网:http://www.mybatis网站站点" rel="nofollow" />
<dataSource type="POOLED">
<!-- MySQL数据库驱动 -->
<property name="driver" value="com.mysql.jdbc.Driver" />
<!-- 连接数据库的URL -->
<property name="url"
value="jdbc:mysql://localhost:3306/test?characterEncoding=utf8" />
<property name="username" value="root" />
<property name="password" value="root" />
</dataSource>
mappers标签
mappers 标签用于指定 MyBatis SQL 映射文件的路径。mapper 是 mappers 的子标签,mapper 中的 resource 属性用于指定 SQL 映射文件的路径(类资源路径)
例如,SQL 映射文件的名称是 Student.xml,它位于名为 net.biancheng.mapper 的包中,那么您可以这样配置:
<mappers>
<mapper resource="net/biancheng/mapper/Student.xml"/>
</mappers>
- 随机文章
- 武汉 马尔代夫(武汉市民欢度疫情后首个国庆 黄金周出境游首选马尔代夫)
- 伊宁马尔代夫视频(伊宁市民用全景相机记录马尔代夫假期)
- 商丘马尔代夫酒吧(商丘市酒吧模仿马尔代夫风情装修营业)
- 天津飞到马尔代夫(直达天堂!从天津飞往马尔代夫的旅程)
- 云和 马尔代夫(云朵漫步 马尔代夫:浪漫之旅)
- 成都马尔代夫简介(成都马尔代夫:遇见城市中的度假天堂)
- 斑马旅行马尔代夫(斑马旅行探索马尔代夫的热带极乐世界)
- 洲际马尔代夫缺点(洲际马尔代夫存在缺点,可否告诉你?)
- 首航 马尔代夫(马尔代夫:新航线首飞成功!)
- 最新马尔代夫疫情(马尔代夫新增近期最高新冠确诊病例数)
- 永州马尔代夫水库(永州市马尔代夫水库一级洪水响应启动)
- 心里 马尔代夫(美妙马尔代夫:世界最美海岛!)
- 男足败给马尔代夫(中国男足惨遭马尔代夫逆袭,遭遇失利)
- 玉林马尔代夫大门(玉林镶嵌马尔代夫,营造热带海岛风情)
- 港丽马尔代夫度假(港丽马尔代夫度假村:远离尘嚣的天堂)
- 阿慕 马尔代夫(阿慕:马尔代夫水下餐厅新打卡地)
- 联通手机马尔代夫(联通手机用户出境,畅享马尔代夫网络)
- 类似马尔代夫岛屿(打造独一无二的珊瑚岛屿,美不胜收!)
- 苏州马尔代夫费用(苏州市民自驾游马尔代夫,费用揭晓!)
- 海南马尔代夫度假(海南有一个像马尔代夫一样的度假胜地)
- 荆州马尔代夫在哪(荆州市民们的马尔代夫游,要去哪里?)
- 盱眙 马尔代夫(盱眙县:马尔代夫爱好者的天堂)
- 国语 马尔代夫(马尔代夫:美丽天堂)
- 松滋 马尔代夫(松滋游客想去的马尔代夫,成了最美妙旅程)
- 马尔代夫上空视频(空中拍摄的马尔代夫海水世界惊艳亮相)
- 马尔代夫仙女照片(美如仙女!马尔代夫旅游照片震撼网友)
- 马尔代夫亚洲健美(亚洲健美:马尔代夫助力选手斩获佳绩)
- 济宁旅游马尔代夫(济宁旅游新选择:畅游神秘的马尔代夫)
- 郴州马尔代夫电话(郴州旅行社提供马尔代夫旅游预定服务)
- 马尔代夫信息大全(马尔代夫详尽指南:必知旅游信息汇总)
