这节来说说全局配置文件的东西,非常简单。看一遍就懂了。

                          --WZY

一、全部配置内容

      SqlMapConfig.xml的配置内容和顺序如下,顺序不能乱。现在来对这些属性的意思一一进行讲解。 

       

   

二、properties

     作用:引用java属性文件中的配置信息,比如,加载连接数据库的各种属性的配置文件。 

       

        

        

         db.properties

          

     <!--
properties:引用java属性文件中的配置信息
比如加载连接数据库的帐号密码等信息的properties配置文件。
使用${}可以引用已经加载的java配置文件中的信息
使用时注意一个问题,mybatis按照下面的顺序加载属性
1、properties标签体内的属性
2、properties引用的属性会被读取,本例中也就是db.properties中的属性(key-value),
如果发现db.properties中有和第一步加载的属性的key相同的属性,那么将其覆盖
3、parameterType:接收的值最后被读取,parameterType="int" int相当于key,而实际上接收到的值
为value,如果parameterType的属性名与前面两步中的属性名相同,那么将其覆盖。
总结:加载的越快,就很有可能被覆盖,所以在properties中的key值都使用db.xxx,目的就是防止重名被覆盖
-->
<properties resource="db.properties">
<!-- 这里就是properties标签体内的属性
比如: <property name="" value=""/>
-->
</properties>
//使用db.properties中的配置信息
<dataSource type="POOLED">
<!-- 引用db.properties中的信息,通过${} -->
<property name="driver" value="${db.driver}"/>
<property name="url" value="${db.url}"/>
<property name="username" value="${db.username}"/>
<property name="password" value="${db.password}"/>
</dataSource>

三、settings

        <!-- setting 全局参数,比如懒加载、是否启动缓存机制-->

        这个在后面讲解懒加载时会讲解到。比如设置懒加载的全局参数

        

     <!-- setting 全局参数,比如懒加载、是否启动缓存机制-->
<settings>
<!-- 打开延迟加载的开关,默认为true -->
<setting name="lazyLoadingEnabled" value="true"/>
<!-- 积极的懒加载,默认是true,设置为false时,懒加载生效 -->
<setting name="aggressiveLazyLoading" value="false"/>
</settings>

四、typeAliases

        别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int,就是在这里设置。(使用推荐的)

        

     <!-- typeAliases:别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int,
而不需要在编写全限定名 java.lang.Integer了。 有很多默认的别名,比如int,String,八大基本类型都是
我们也可以自定义别名,
com.wuhao.mybatis.domain.User 使用别名 user 代替
-->
<typeAliases>
<!-- 单个定义别名 -->
<typeAlias type="com.wuhao.mybatis.domain.User" alias="user"/>
<!-- 批量定义别名(推荐)
指定批量定义别名的类包,在此包下的所有类都将可以使用别名,别名就为类名(首字母大小写都可以)
-->
<!-- <package name="com.wuhao.mybatis.domain"/> -->
</typeAliases>

        mybatis中有很多默认的别名,也就是帮我们写好了的,比如八大基本类型,

            

五、typeHandlers

        类型转换器,将数据库的类型转换成java的类型,mybatis会帮我们做这个事情,我们不需要自己设置,在mybatis的jar包中,有一个

                      

        其中就会将类型转换器,转换哪些java类型都会列举出来,我们去看看,用来借鉴借鉴,等用到了可以到里面查查,

              

六、objectFactory

        对象工厂不用管,因为到时候肯定和spring整合,都会由sprig来管理,到与spring整合的时候就会讲解到对象工厂的了。

七、mappers

        加载映射文件,也就是我们配置的映射文件,在这里需要显示声明加载。有四种方式加载,使用推荐的那种,其他的了解

              

        使用第四种方式加载

              

     <!--
mappers:加载映射文件
四种方式来加载
1、<mapper resource="config/sqlmap/user.xml"/>
使用相对路径,相对于项目底下。,比如config下的sqlmap下的user.xml
2、<mapper url=’’/>
使用绝对路径,比如d盘下的xx,不会用这种
3、<mapper class=’’/>
使用mapper接口的全县定名。就不用管路径问题了,让mybatis通过全限定名自己去找映射文件
前提:mapper接口的名称必须与映射文件的名称相同,并且放到一个目录下,
比如:UserMapper.java(接口) UserMapper.xml(映射文件)
4、<package name=’’/>(推荐)
注册指定包下的所有映射文件
<package name="com.wuhao.mapper"/>
配置了com.wuhao.mapper下的所有映射文件,
注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下
-->
<mappers>
<!-- <mapper resource="sqlmap/User.xml"/> -->
<!-- 批量加载映射文件 -->
<package name="com.wuhao.mapper"/>
<package name="com.wuhao.shuru"/>
<package name="com.wuhao.resultMap"/>
<package name="com.wuhao.onetoone"/>
</mappers>

八,总的配置文件代码        

 <?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>
<!--
属性
<properties></properties>
全局参数设置
<settings></settings>
类型别名
<typeAliases></typeAliases>
类型处理器
<typeHandles></typeHandles>
对象工厂
<objectFactory></objectFactory>
插件
<plugins></plugins>
以上属性在后边会详细讲解到,现在我们就只需要关注一下下面的配置即可
如下所配置的就是使用这点东西。
environments(环境信息集合)
environment(单个环境信息)
transactionManager(事物)
dataSource(数据源)
environment
environments
mappers(映射器)
--> <!--
properties:引用java属性文件中的配置信息
比如加载连接数据库的帐号密码等信息的properties配置文件。
使用${}可以引用已经加载的java配置文件中的信息
使用时注意一个问题,mybatis按照下面的顺序加载属性
1、properties标签体内的属性
2、properties引用的属性会被读取,本例中也就是db.properties中的属性(key-value),
如果发现db.properties中有和第一步加载的属性的key相同的属性,那么将其覆盖
3、parameterType:接收的值最后被读取,parameterType="int" int相当于key,而实际上接收到的值
为value,如果parameterType的属性名与前面两步中的属性名相同,那么将其覆盖。
总结:加载的越快,就很有可能被覆盖,所以在properties中的key值都使用db.xxx,目的就是防止重名被覆盖
-->
<properties resource="db.properties">
<!-- 这里就是properties标签体内的属性
比如: <property name="" value=""/>
-->
</properties> <!-- setting 全局参数,比如懒加载、是否启动缓存机制-->
<!-- <settings>
打开延迟加载的开关,默认为true
<setting name="lazyLoadingEnabled" value="true"/>
积极的懒加载,默认是true,设置为false时,懒加载生效
<setting name="aggressiveLazyLoading" value="false"/>
</settings> --> <!-- typeAliases:别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int,
而不需要在编写全限定名 java.lang.Integer了。 有很多默认的别名,比如int,String,八大基本类型都是
我们也可以自定义别名,
com.wuhao.mybatis.domain.User 使用别名 user 代替
-->
<typeAliases>
<!-- 单个定义别名 -->
<typeAlias type="com.wuhao.mybatis.domain.User" alias="user"/>
<!-- 批量定义别名(推荐)
指定批量定义别名的类包,在此包下的所有类都将可以使用别名,别名就为类名(首字母大小写都可以)
-->
<!-- <package name="com.wuhao.mybatis.domain"/> -->
</typeAliases> <!-- 类型转换器,将数据库的类型转换成java的类型,
mybatis会帮我们做这个事情,我们不需要自己设置,
<typeHandlers></typeHandlers>
--> <!--
对象工厂不用管,因为到时候肯定和spring整合,都会由sprig来管理。
<objectFactory></objectFactory>
--> <!--
mappers:加载映射文件
四种方式来加载
1、<mapper resource="config/sqlmap/user.xml"/>
使用相对路径,相对于项目底下。,比如config下的sqlmap下的user.xml
2、<mapper url=’’/>
使用绝对路径,比如d盘下的xx,不会用这种
3、<mapper class=’’/>
使用mapper接口的全县定名。就不用管路径问题了,让mybatis通过全限定名自己去找映射文件
前提:mapper接口的名称必须与映射文件的名称相同,并且放到一个目录下,
比如:UserMapper.java(接口) UserMapper.xml(映射文件)
4、<package name=’’/>(推荐)
注册指定包下的所有映射文件
<package name="com.wuhao.mapper"/>
配置了com.wuhao.mapper下的所有映射文件,
注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下
--> <!-- 配置mybatis的环境信息 -->
<environments default="development">
<environment id="development">
<!-- 配置JDBC事务控制,由mybatis进行管理 -->
<transactionManager type="JDBC"></transactionManager>
<!-- 配置数据源,采用dbcp连接池 -->
<dataSource type="POOLED">
<!-- 引用db.properties中的信息,通过${} -->
<property name="driver" value="${db.driver}"/>
<property name="url" value="${db.url}"/>
<property name="username" value="${db.username}"/>
<property name="password" value="${db.password}"/>
</dataSource>
</environment>
</environments>
<!-- 加载mapper映射文件 -->
<mappers>
<!-- <mapper resource="sqlmap/User.xml"/> -->
<!-- 批量加载映射文件 -->
<package name="com.wuhao.mapper"/>
<package name="com.wuhao.shuru"/>
<package name="com.wuhao.resultMap"/>
<package name="com.wuhao.onetoone"/>
</mappers>
</configuration>

九、总结

      以上就把全局配置文件中的内容全部给讲解了一遍,其中

          

      没有具体讲解这个,因为都是死东西,在前一章节都是使用这个,所以就不在过多分析,其他的都有讲解到是什么作用,现在应该对前面一章的东西有更加深入的理解,但是需要彻底理解,还需要等待下一章讲解映射文件之后才能够更加清晰。加油。

Mybatis(二) 全局配置文件详解的更多相关文章

  1. MyBatis 全局配置文件详解(七)

    MyBatis 配置文件作用 MyBatis配置文件包含影响 MyBatis 框架正常使用的功能设置和属性信息.它的作用好比手机里的设置图标,点击这个图标就可以帮助我们查看手机的属性信息和设置功能.其 ...

  2. 2017.2.9 深入浅出MyBatis技术原理与实践-第八章 MyBatis-Spring(二)-----配置文件详解

    深入浅出MyBatis技术原理与实践-第八章 MyBatis-Spring(二) ------配置文件详解 8.2 MyBatis-Spring应用 8.2.1 概述 本文主要讲述通过注解配置MyBa ...

  3. Mybatis学习(二)————— 全局配置文件详解

    一.全部配置内容 SqlMapConfig.xml的配置内容和顺序如下,顺序不能乱.现在来对这些属性的意思一一进行讲解. 二.properties 作用:引用java属性文件中的配置信息,比如,加载连 ...

  4. Mybatis全局配置文件详解(三)

    每个基于Mybatis应用都是以一个SqlSessionFactory实例为中心.SqlSessionFactory实例可以由SqlSessionFactoryBuild获得,而SqlSessionF ...

  5. MyBatis系列:二、配置文件详解

    本文会详细介绍MyBatis的常用配置 1.properties节点 <properties resource="mybatis-config.properties"> ...

  6. mybatis加载配置文件详解

    spring整合Mybatis后,SqlSessionFactory的创建由spring进行了代理,以下是SqlSessionFactory创建的流程 SqlSessionFactoryBean: p ...

  7. nginx安装及配置文件详解

    一)nginx安装及模块讲解 1.1.nginx安装步骤 mkdir /soft wget http://nginx.org/download/nginx-1.12.0.tar.gz tar zxf ...

  8. MyBatis核心配置文件详解

    ------------------------siwuxie095                                     MyBatis 核心配置文件详解         1.核心 ...

  9. (原创)LAMP搭建之二:apache配置文件详解(中英文对照版)

    LAMP搭建之二:apache配置文件详解(中英文对照版) # This is the main Apache server configuration file. It contains the # ...

随机推荐

  1. Java中位运算符的使用

    先预知识: 数据在计算机中是以二进制的形式进行存储的,而二进制在内存中是以补码的形式进行存储的.在介绍位运算之前,首先来看一下原码.反码和补码的概念.由于正数的原码.反码和补码的形式都是一样的,所以以 ...

  2. spring boot默认访问静态资源

    演示spring boot默认可以直接访问静态资源的2种方法: 第一种:在src/main/resources资源目录下创建一个名为"static"的文件夹(该文件夹的名称是规定死 ...

  3. PSD的单位及计算方法[转]

      功率谱密度(PSD)的国际单位 功率谱密度(PSD),单位为:unit^2/Hz代表单位频率上信号的能量,所以是密度谱,幅值代表频段内的有效值平方. 如果是加速度功率谱密度,加速度的单位是m/s^ ...

  4. webpack 入门踩坑

    参考来源:知乎张轩 安装 先装好node和npm,因为webpack是一个基于node的项目.然后 npm install -g webpack 全局安装 还可以在当前项目里面也安装一个webpack ...

  5. Fenng对于管理技术团队的思考

    丁香园CTO冯大辉谈技术团队管理 http://www.infoq.com/cn/interviews/fdh-team-manager http://www.geekpark.net/topics/ ...

  6. LeetCode(12. 整数转罗马数字)

    问题描述 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写做 II , ...

  7. js点击回到顶部2

    <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>点 ...

  8. npm install 提示权限不足 Error: EPERM: operation not permitted, unlink XXX

    问题 使用npm install时提示权限不足 原因 这里原因有两个: 没有管理员权限访问C盘下npm路径导致下载失败. NPM官网没有下载权限. 解决方案 第一原因 这里可以使用管理员身份执行以下命 ...

  9. javaweb数据库编程代码详细讲解

    import java.sql.*; /*默写数据库练习数据库编程及注释讲解代码*/ public class Main{ public static void main(String[]args)t ...

  10. chardet查看字符串的编码(非常好用)

    chardet不是python自带的包需要手动安装 chardet安装命令(dos下): pip install chardet 或: pip.exe install chardet 案例: > ...