一、properties

此标签的主要作用是引用配置文件,以数据源来举例。

新建mybatis-confing.properties配置文件

mybatis-confing.properties

  1. driver=com.mysql.cj.jdbc.Driver
  2. url=jdbc:mysql://127.0.0.1:3306/test?serverTimezone=UTC&useSSL=false
  3. username=root
  4. password=Yuhao@520

在MyBatis配置文件mybatis-confing.xml文件中引用外部配置文件

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE configuration
  3. PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-config.dtd">
  5. <configuration>
  6. <!-- 引用mybatis-confing.properties配置文件 -->
  7. <properties resource="mybatis-confing.properties" />
  8.  
  9. <environments default="development">
  10. <environment id="development">
  11. <transactionManager type="JDBC" />
  12. <dataSource type="POOLED">
  13. <!-- 可以通过${}标签结合外部配置文件的属性名称进行配置引用 -->
  14. <property name="driver" value="${driver}" />
  15. <property name="url" value="${url}" />
  16. <property name="username" value="${username}" />
  17. <property name="password" value="${password}" />
  18. </dataSource>
  19. </environment>
  20. </environments>
  21. <!-- 将我们写好的sql映射文件(PolicyMapper.xml)一定要注册到全局配置文件(mybatis-config.xml)中 -->
  22. <mappers>
  23. <mapper resource="PolicyMapper.xml" />
  24. </mappers>
  25. </configuration>

二、setting

settings是MyBatis中最复杂的配置,它能影响MyBatis底层的运行,大部分情况下使用默认值,如果需要改动只需要改动需要用到的部分即可。

三、typeAliases

类型别名是为 Java 类型设置一个短的名字。 它只和 XML 配置有关,存在的意义仅在于用来减少类完全限定名的冗余。

MyBatis全局配置文件

  1. <typeAliases>
  2. <typeAlias alias="Music" type="com.mybatis.bean.music" />
  3. </typeAliases>

在需要使用全量的地方可使用别名,如:

SQL的resultType上可以直接使用Policy不需要再写全量类名

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="com.mybatis.dao.selectall">
  6.  
  7. <select id="selectmusicall" resultType="Music">
  8. select id,name,music,musicurl from test where name = #{name};
  9. </select>
  10.  
  11. </mapper>

注解的方式起别名,在包com.mybatis.bean下的类中使用@Alias注解的类,可以直接使用注解属性,实现与typeAlias给定别名一样的效果。

Music类

  1. @Alias("Music")
  2. public class Music{
  3. ...
  4. }

MyBatis全局配置文件

  1. <typeAliases>
  2. <package name="com.mybatis.bean" />
  3. </typeAliases>

四、environments

环境配置可以通过default来选择连接到那个数据源,可以用来做不同环境的切换。

  1. <environments default="dev_sit">
  2. <!-- 使用environment标签,可以根据环境的不同进行连接库的切换 -->
  3. <environment id="dev_sit">
  4. <transactionManager type="JDBC" />
  5. <dataSource type="POOLED">
  6. <!-- 可以通过${}标签结合外部配置文件的属性名称进行配置引用 -->
  7. <property name="driver" value="${sit_driver}" />
  8. <property name="url" value="${sit_url}" />
  9. <property name="username" value="${sit_username}" />
  10. <property name="password" value="${sit_password}" />
  11. </dataSource>
  12. </environment>
  13.  
  14. <environment id="dev_uat">
  15. <transactionManager type="JDBC" />
  16. <dataSource type="POOLED">
  17. <!-- 可以通过${}标签结合外部配置文件的属性名称进行配置引用 -->
  18. <property name="driver" value="${uat_driver}" />
  19. <property name="url" value="${uat_url}" />
  20. <property name="username" value="${uat_username}" />
  21. <property name="password" value="${uat_password}" />
  22. </dataSource>
  23. </environment>
  24. </environments>

五、mappers

SQL映射有四种实现方式

使用相对于类路径的资源引用

  1. <mappers>
  2. <mapper resource="MyBatisMapper/MusicMapper.xml"/>
  3. </mappers>

使用完全限定资源定位符(URL)

  1. <mappers>
  2. <mapper url="file:///var/mappers/AuthorMapper.xml"/>
  3. <mapper url="file:///var/mappers/BlogMapper.xml"/>
  4. <mapper url="file:///var/mappers/PostMapper.xml"/>
  5. </mappers>

使用映射器接口实现类的完全限定类名

  1. <mappers>
  2. <mapper class="org.mybatis.builder.AuthorMapper"/>
  3. <mapper class="org.mybatis.builder.BlogMapper"/>
  4. <mapper class="org.mybatis.builder.PostMapper"/>
  5. </mappers>

将包内的映射器接口实现全部注册为映射器

  1. <mappers>
  2. <package name="org.mybatis.builder"/>
  3. </mappers>

MyBatis系列(三) MyBatis 配置文件的更多相关文章

  1. MyBatis系列三 之 使用getMapper剔除掉Dao的实现类

    MyBatis系列三  之  使用getMapper剔除掉Dao的实现类 我们在系列一 中 我们使用的是Dao的实现类   来操作底层数据库,今天我们使用getMapper()来替换Dao的实现类, ...

  2. 深入浅出Mybatis系列三-配置详解之properties与environments(mybatis源码篇)

    注:本文转载自南轲梦 注:博主 Chloneda:个人博客 | 博客园 | Github | Gitee | 知乎 上篇文章<深入浅出Mybatis系列(二)---配置简介(mybatis源码篇 ...

  3. 深入浅出Mybatis系列一-Mybatis入门

    注:本文转载自南轲梦 注:博主 Chloneda:个人博客 | 博客园 | Github | Gitee | 知乎 最近两年 springmvc + mybatis 的在这种搭配还是蛮火的,楼主我呢, ...

  4. Mybatis系列(三):Mybatis实现关联表查询

    原文链接:http://www.cnblogs.com/xdp-gacl/p/4264440.html 一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 ...

  5. MyBatis学习(三)---MyBatis和Spring整合

    想要了解MyBatis基础的朋友可以通过传送门: MyBatis学习(一)---配置文件,Mapper接口和动态SQL http://www.cnblogs.com/ghq120/p/8322302. ...

  6. mybatis入门(三):mybatis的基础特性

    mybatis的知识点: 1.mybatis和hibernate本质区别和应用场景 hibernate:是一个标准的ORM框架(Ojbect relation mapper对象关系映射).入门门槛较高 ...

  7. 深入迁出mybatis系列

    本系列教程均源于南柯梦,经好库文摘转发,感谢南柯梦的辛苦整理. 深入迁出mybatis系列 深入浅出Mybatis系列(一)---Mybatis入门 深入浅出Mybatis系列(二)---配置简介(m ...

  8. MyBatis学习系列三——结合Spring

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring MyBatis在项目中应用一般都要结合Spring,这一章主要把MyBat ...

  9. Mybatis系列(三)XML

    Mybatis系列(三)XML 1.pom.xml依赖: <?xml version="1.0" encoding="UTF-8"?> <pr ...

  10. Mybatis系列全解(四):全网最全!Mybatis配置文件XML全貌详解

    封面:洛小汐 作者:潘潘 做大事和做小事的难度是一样的.两者都会消耗你的时间和精力,所以如果决心做事,就要做大事,要确保你的梦想值得追求,未来的收获可以配得上你的努力. 前言 上一篇文章 <My ...

随机推荐

  1. shell $x的含义

    linux中shell变量$#,$@,$0,$1,$2的含义解释: 变量说明: $$ Shell本身的PID(ProcessID) $! Shell最后运行的后台Process的PID $? 最后运行 ...

  2. Ingress-Nginx

    注意:  本文只用的ingress-nginx版本为0.24.1,可在官方网站自行下载 https://github.com/kubernetes/ingress-nginx 一.Ingress-Ng ...

  3. Linux shell while循环语句

    for :明确循环次数 while :不确定循环换次数 while循环 (1) while CONDITION:do       statement       statement       < ...

  4. HDU 2612 Find a way 题解

    Find a way Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  5. win10锁屏壁纸文件夹位置

    Win10默认系统下载的壁纸怎么下载?在哪里找出来呢?首先我们要把系统的锁屏壁纸要设置为Windows聚焦才会自动从微软的服务器上去下载壁纸.这些都是随机下载的.每个人的都Win10 都有可能不一样. ...

  6. 【Linux】文件拷贝-Linux当前目录所有文件移动到上一级目录(转)

    Linux当前目录所有文件移动到上一级目录 mv * ../

  7. serialize()和new FormData()的区别

    serialize()和FormData对象都可将表单数据序列化,后通过ajax异步提交 ,序列化表单就是将form表单中所有name属性序列化成KEY-VALUE的形式,提交到后台,后台以对象相应的 ...

  8. 复制excel表中的数据

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. SQL Server 默认跟踪(Trace)捕获事件详解

    SQL Server 默认跟踪 -- 捕获事件详解 哪些具体事件默认跟踪文件能够捕获到? --returns full list of events SELECT * FROM sys.trace_e ...

  10. monkey--常用参数

    前戏 参数分类:常规类参数,事件类参数,约束类参数,调试类参数 常规类参数:常规类参数包括帮助参数和日志信息参数,帮助参数用于输出monkey命令使用指导,日志信息参数将日志分为三个等级,级别越高,日 ...