MyBatis基础入门《五》核心配置文件
MyBatis基础入门《五》核心配置文件
描述:
在前面的章节中,简单的学习使用了一下mybatis,对于配置文件没有过多详细说明。
这里先描述项目中的一个核心配置文件:mybatis-config.xml 文件。
资料参考:http://www.mybatis.org/mybatis-3/
<?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> <!-- 可以配置在java属性配置文件中 -->
<properties></properties> <!-- 修改MyBatis在运行时的行为方式 -->
<settings></settings> <!-- 为java类命令一个别名(简称) -->
<typeAliases></typeAliases> <!-- 类型处理器 -->
<typeHandlers></typeHandlers> <!-- 对象工厂 -->
<objectFactory type=""></objectFactory> <!-- 插件 -->
<plugins></plugins> <!-- 环境 -->
<environments default=""> <!-- 环境变量 -->
<environment id=""> <!-- 配置事物管理器 -->
<transactionManager type=""></transactionManager>
<!-- 配置数据源 -->
<dataSource type=""></dataSource> </environment> </environments> <!-- 映射器 -->
<mappers></mappers> </configuration>
注意:
上面的这个配置文件中的标签,在书写的时候必须要按照这个顺序,不然Mybatis在解析这个文件的时候,会报错的。
<properties></properties>
>>> 配置properties元素的两种方式
1. 通过外部指定的方式(database.properties),实现动态配置
> 配置properties的resource属性

前面章节中使用是这种方式,在位置1处,进行外部引入。然后在位置2处使用。
2. 直接配置为xml,实现动态配置
> properties 的name和value

properties问题:
1. 若两种方式同时都用了,那么哪种方式优先?
> 配置properties的resource指定
> 配置property的name和value

测试方式:
1. 修改标签property的value属性值,运行查询测试方法,可以正常执行。
2. 恢复被修改的property标签的value属性值,然后修改database.properties文件中的数据,在运行查询测试方法,程序抛出异常错误。
结论: resource属性值的优先级高于property子节点配置的值。
<settings></settings>
1. 用来修改MyBatis运行时的行为方式
2. 主要是MyBatis的一些全局配置属性的设置
例如:配置一个延迟加载

<typeAliases></typeAliases>
1. 用来修改类型别名
2. 仅仅只关联XML配置,简写冗长的java名,用法见:《MyBatis基础入门《三》Select查询集合》 select查询方式3

<environments></environments>
1. 表示配置MyBatis的多套运行环境,将SQL映射到多个不同的数据库上
2. 子元素节点:environment,但是必须指定其中一个为默认运行环境(通过default指定)

<transactionManager></transactionManager> 事物管理器
<transactionManager type = "[ JDBC | MANAGED]" />
jdbc | managed 托管
<dataSource></dataSource>
>>> dataSource元素使用的基本的JDBC数据源接口来配置JDBC连接对象的资源
>>> 有三种内建的数据源类型
<dataSource type="[ UNPOOLED | POOLED | JNDI ]" />
<mappers></mappers>
1. 映射器,定义SQL映射语句
2. 须在配置中引用Mapper映射文件

... ...
如有问题,欢迎纠正!!!
如有转载,请标明源处:https://www.cnblogs.com/Charles-Yuan/p/9862302.html
参考资料:http://www.mybatis.org/mybatis-3/zh/configuration.html
MyBatis基础入门《五》核心配置文件的更多相关文章
- MyBatis基础入门《十五》ResultMap子元素(collection)
MyBatis基础入门<十五>ResultMap子元素(collection) 描述: 见<MyBatis基础入门<十四>ResultMap子元素(association ...
- Mybatis基础入门学习
Mybatis基础入门学习 mybatis架构分析 搭建测试mybatis架构 )下载并导入mybatis3.2.7.jar(架构),mysql-connector-java-5.1.7-bin.ja ...
- MyBatis基础入门《十七》动态SQL
MyBatis基础入门<十七>动态SQL 描述: >> 完成多条件查询等逻辑实现 >> 用于实现动态SQL的元素主要有: > if > trim > ...
- MyBatis基础入门《三》Select查询集合
MyBatis基础入门<三>Select查询集合 描述: 代码新增了一个MybatisUtil工具类,查询数据库返回集合的时候,接收数据的三种方式.由于代码会渐渐增多,未涉及改动过的文件不 ...
- MyBatis基础入门《二》Select查询
MyBatis基础入门<二>Select查询 使用MySQL数据库,创建表: SET NAMES utf8mb4; ; -- ---------------------------- -- ...
- MyBatis基础入门
1.MyBatis概述 MyBatis是一个优秀的持久层框架,它对jdbc的操作数据库的过程进行封装,使开发者只需要关注 SQL 本身,而不需要花费精力去处理例如注册驱动.创建connection.创 ...
- MyBatis基础入门《二十》动态SQL(foreach)
MyBatis基础入门<二十>动态SQL(foreach) 1. 迭代一个集合,通常用于in条件 2. 属性 > item > index > collection : ...
- MyBatis基础入门《十九》动态SQL(set,trim)
MyBatis基础入门<十九>动态SQL(set,trim) 描述: 1. 问题 : 更新用户表数据时,若某个参数为null时,会导致更新错误 2. 分析: 正确结果: 若某个参数为nul ...
- MyBatis基础入门《十八》动态SQL(if-where)
MyBatis基础入门<十八>动态SQL(if-where) 描述: 代码是在<MyBatis基础入门<十七>动态SQL>基础上进行改造的,不再贴所有代码,仅贴改动 ...
随机推荐
- 如何使用IcoMoon字体图标
如何使用IcoMoon字体图标 一,字体图标工具: 1.登录字体图标网站:https://icomoon.io/app/#/select 2.Svg在线编辑工具:https://c.runoob.co ...
- Spring <context:annotation-config> 与<context-component-scan> 的作用
<context:annotation-config> 与<context-component-scan> 的作用 <context:annotation-config& ...
- php新加扩展模块
记录下在已经编译安装的PHP上面增加扩展模块,下面以安装mbstring.so为例 1.进入PHP源码文件中的mbstring文件夹,一般都是在ext目录 cd php-5.5.29/ext/mbst ...
- 406 UDP协议是面向非连接的协议
HTTP The Definitive Guide Table 3-1. Common HTTP methods Method Description Message body? GET ...
- mvc 使用Newtonsoft.Json进行序列化json数据
mvc 使用Newtonsoft.Json进行序列化json数据 JsonResult 使用js 序列号化,先集成扩展.使用newtonsoft http://blog.csdn.net/zhang ...
- Altium Designer 绘图流程及快捷键
1.Shift+Ctrl+g 设置栅格捕捉大小 2.Q 切换单位 3.E+N +点击字体 改变字体大小 4.自动布线前需在Mechanical 层和keepout层添加一个边框 5.打过孔实现双面走线 ...
- scala-数组/列表
import scala.collection.mutable.ArrayBuffer var ary=Array(1,2,3) println(ary.mkString) println(ary(1 ...
- jquery中选取兄弟节点的方法
$('#id').siblings() 当前元素所有的兄弟节点$('#id').prev() 当前元素前一个兄弟节点$('#id').prevaAll() 当前元素之前所有的兄弟节点$('#id'). ...
- python摸爬滚打之day02----while循环,运算符,格式化输出
1.while循环 1.1 结构:while +条件判断: while 循环体 else: 条件不成立时语句块 while...else...是一个循环整体,当循环条件成立时执行while循环体内容 ...
- 深入SQL Server优化【推荐】
深入sql server优化,MSSQL优化,T-SQL优化,查询优化 十步优化SQL Server 中的数据访问故事开篇:你和你的团队经过不懈努力,终于使网站成功上线,刚开始时,注册用户较少,网站性 ...