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基础入门《五》核心配置文件的更多相关文章

  1. MyBatis基础入门《十五》ResultMap子元素(collection)

    MyBatis基础入门<十五>ResultMap子元素(collection) 描述: 见<MyBatis基础入门<十四>ResultMap子元素(association ...

  2. Mybatis基础入门学习

    Mybatis基础入门学习 mybatis架构分析 搭建测试mybatis架构 )下载并导入mybatis3.2.7.jar(架构),mysql-connector-java-5.1.7-bin.ja ...

  3. MyBatis基础入门《十七》动态SQL

    MyBatis基础入门<十七>动态SQL 描述: >> 完成多条件查询等逻辑实现 >> 用于实现动态SQL的元素主要有: > if > trim > ...

  4. MyBatis基础入门《三》Select查询集合

    MyBatis基础入门<三>Select查询集合 描述: 代码新增了一个MybatisUtil工具类,查询数据库返回集合的时候,接收数据的三种方式.由于代码会渐渐增多,未涉及改动过的文件不 ...

  5. MyBatis基础入门《二》Select查询

    MyBatis基础入门<二>Select查询 使用MySQL数据库,创建表: SET NAMES utf8mb4; ; -- ---------------------------- -- ...

  6. MyBatis基础入门

    1.MyBatis概述 MyBatis是一个优秀的持久层框架,它对jdbc的操作数据库的过程进行封装,使开发者只需要关注 SQL 本身,而不需要花费精力去处理例如注册驱动.创建connection.创 ...

  7. MyBatis基础入门《二十》动态SQL(foreach)

    MyBatis基础入门<二十>动态SQL(foreach) 1. 迭代一个集合,通常用于in条件 2. 属性 > item > index > collection : ...

  8. MyBatis基础入门《十九》动态SQL(set,trim)

    MyBatis基础入门<十九>动态SQL(set,trim) 描述: 1. 问题 : 更新用户表数据时,若某个参数为null时,会导致更新错误 2. 分析: 正确结果: 若某个参数为nul ...

  9. MyBatis基础入门《十八》动态SQL(if-where)

    MyBatis基础入门<十八>动态SQL(if-where) 描述: 代码是在<MyBatis基础入门<十七>动态SQL>基础上进行改造的,不再贴所有代码,仅贴改动 ...

随机推荐

  1. 如何使用IcoMoon字体图标

    如何使用IcoMoon字体图标 一,字体图标工具: 1.登录字体图标网站:https://icomoon.io/app/#/select 2.Svg在线编辑工具:https://c.runoob.co ...

  2. Spring <context:annotation-config> 与<context-component-scan> 的作用

    <context:annotation-config> 与<context-component-scan> 的作用 <context:annotation-config& ...

  3. php新加扩展模块

    记录下在已经编译安装的PHP上面增加扩展模块,下面以安装mbstring.so为例 1.进入PHP源码文件中的mbstring文件夹,一般都是在ext目录 cd php-5.5.29/ext/mbst ...

  4. 406 UDP协议是面向非连接的协议

    HTTP The Definitive Guide   Table 3-1. Common HTTP methods   Method Description Message body?   GET ...

  5. mvc 使用Newtonsoft.Json进行序列化json数据

    mvc 使用Newtonsoft.Json进行序列化json数据 JsonResult  使用js 序列号化,先集成扩展.使用newtonsoft http://blog.csdn.net/zhang ...

  6. Altium Designer 绘图流程及快捷键

    1.Shift+Ctrl+g 设置栅格捕捉大小 2.Q 切换单位 3.E+N +点击字体 改变字体大小 4.自动布线前需在Mechanical 层和keepout层添加一个边框 5.打过孔实现双面走线 ...

  7. scala-数组/列表

    import scala.collection.mutable.ArrayBuffer var ary=Array(1,2,3) println(ary.mkString) println(ary(1 ...

  8. jquery中选取兄弟节点的方法

    $('#id').siblings() 当前元素所有的兄弟节点$('#id').prev() 当前元素前一个兄弟节点$('#id').prevaAll() 当前元素之前所有的兄弟节点$('#id'). ...

  9. python摸爬滚打之day02----while循环,运算符,格式化输出

    1.while循环 1.1  结构:while +条件判断: while 循环体 else: 条件不成立时语句块 while...else...是一个循环整体,当循环条件成立时执行while循环体内容 ...

  10. 深入SQL Server优化【推荐】

    深入sql server优化,MSSQL优化,T-SQL优化,查询优化 十步优化SQL Server 中的数据访问故事开篇:你和你的团队经过不懈努力,终于使网站成功上线,刚开始时,注册用户较少,网站性 ...