Mybatis学习(二)————— 全局配置文件详解
一、全部配置内容
SqlMapConfig.xml的配置内容和顺序如下,顺序不能乱。现在来对这些属性的意思一一进行讲解。
二、properties
作用:引用java属性文件中的配置信息,比如,加载连接数据库的各种属性的配置文件。
db.properties
1 <!--
2 properties:引用java属性文件中的配置信息
3 比如加载连接数据库的帐号密码等信息的properties配置文件。
4 使用${}可以引用已经加载的java配置文件中的信息
5 使用时注意一个问题,mybatis按照下面的顺序加载属性
6 1、properties标签体内的属性
7 2、properties引用的属性会被读取,本例中也就是db.properties中的属性(key-value),
8 如果发现db.properties中有和第一步加载的属性的key相同的属性,那么将其覆盖
9 3、parameterType:接收的值最后被读取,parameterType="int" int相当于key,而实际上接收到的值
10 为value,如果parameterType的属性名与前面两步中的属性名相同,那么将其覆盖。
11 总结:加载的越快,就很有可能被覆盖,所以在properties中的key值都使用db.xxx,目的就是防止重名被覆盖
12 -->
13 <properties resource="db.properties">
14 <!-- 这里就是properties标签体内的属性
15 比如: <property name="" value=""/>
16 -->
17 </properties>
18 //使用db.properties中的配置信息
19 <dataSource type="POOLED">
20 <!-- 引用db.properties中的信息,通过${} -->
21 <property name="driver" value="${db.driver}"/>
22 <property name="url" value="${db.url}"/>
23 <property name="username" value="${db.username}"/>
24 <property name="password" value="${db.password}"/>
25 </dataSource>

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

三、settings
<!-- setting 全局参数,比如懒加载、是否启动缓存机制-->
这个在后面讲解懒加载时会讲解到。比如设置懒加载的全局参数
1 <!-- setting 全局参数,比如懒加载、是否启动缓存机制-->
2 <settings>
3 <!-- 打开延迟加载的开关,默认为true -->
4 <setting name="lazyLoadingEnabled" value="true"/>
5 <!-- 积极的懒加载,默认是true,设置为false时,懒加载生效 -->
6 <setting name="aggressiveLazyLoading" value="false"/>
7 </settings>
8

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

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

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

mybatis中有很多默认的别名,也就是帮我们写好了的,比如八大基本类型,
五、typeHandlers
类型转换器,将数据库的类型转换成java的类型,mybatis会帮我们做这个事情,我们不需要自己设置,在mybatis的jar包中,有一个
其中就会将类型转换器,转换哪些java类型都会列举出来,我们去看看,用来借鉴借鉴,等用到了可以到里面查查,
六、objectFactory
对象工厂不用管,因为到时候肯定和spring整合,都会由sprig来管理,到与spring整合的时候就会讲解到对象工厂的了。
七、mappers
加载映射文件,也就是我们配置的映射文件,在这里需要显示声明加载。有四种方式加载,使用推荐的那种,其他的了解
使用第四种方式加载
1 <!--
2 mappers:加载映射文件
3 四种方式来加载
4 1、<mapper resource="config/sqlmap/user.xml"/>
5 使用相对路径,相对于项目底下。,比如config下的sqlmap下的user.xml
6 2、<mapper url=’’/>
7 使用绝对路径,比如d盘下的xx,不会用这种
8 3、<mapper class=’’/>
9 使用mapper接口的全县定名。就不用管路径问题了,让mybatis通过全限定名自己去找映射文件
10 前提:mapper接口的名称必须与映射文件的名称相同,并且放到一个目录下,
11 比如:UserMapper.java(接口) UserMapper.xml(映射文件)
12 4、<package name=’’/>(推荐)
13 注册指定包下的所有映射文件
14 <package name="com.wuhao.mapper"/>
15 配置了com.wuhao.mapper下的所有映射文件,
16 注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下
17 -->
18 <mappers>
19 <!-- <mapper resource="sqlmap/User.xml"/> -->
20 <!-- 批量加载映射文件 -->
21 <package name="com.wuhao.mapper"/>
22 <package name="com.wuhao.shuru"/>
23 <package name="com.wuhao.resultMap"/>
24 <package name="com.wuhao.onetoone"/>
25 </mappers>

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

八,总的配置文件代码
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 <!--
7 属性
8 <properties></properties>
9 全局参数设置
10 <settings></settings>
11 类型别名
12 <typeAliases></typeAliases>
13 类型处理器
14 <typeHandles></typeHandles>
15 对象工厂
16 <objectFactory></objectFactory>
17 插件
18 <plugins></plugins>
19 以上属性在后边会详细讲解到,现在我们就只需要关注一下下面的配置即可
20 如下所配置的就是使用这点东西。
21 environments(环境信息集合)
22 environment(单个环境信息)
23 transactionManager(事物)
24 dataSource(数据源)
25 environment
26 environments
27 mappers(映射器)
28 -->
29
30 <!--
31 properties:引用java属性文件中的配置信息
32 比如加载连接数据库的帐号密码等信息的properties配置文件。
33 使用${}可以引用已经加载的java配置文件中的信息
34 使用时注意一个问题,mybatis按照下面的顺序加载属性
35 1、properties标签体内的属性
36 2、properties引用的属性会被读取,本例中也就是db.properties中的属性(key-value),
37 如果发现db.properties中有和第一步加载的属性的key相同的属性,那么将其覆盖
38 3、parameterType:接收的值最后被读取,parameterType="int" int相当于key,而实际上接收到的值
39 为value,如果parameterType的属性名与前面两步中的属性名相同,那么将其覆盖。
40 总结:加载的越快,就很有可能被覆盖,所以在properties中的key值都使用db.xxx,目的就是防止重名被覆盖
41 -->
42 <properties resource="db.properties">
43 <!-- 这里就是properties标签体内的属性
44 比如: <property name="" value=""/>
45 -->
46 </properties>
47
48 <!-- setting 全局参数,比如懒加载、是否启动缓存机制-->
49 <!-- <settings>
50 打开延迟加载的开关,默认为true
51 <setting name="lazyLoadingEnabled" value="true"/>
52 积极的懒加载,默认是true,设置为false时,懒加载生效
53 <setting name="aggressiveLazyLoading" value="false"/>
54 </settings> -->
55
56 <!-- typeAliases:别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int,
57 而不需要在编写全限定名 java.lang.Integer了。 有很多默认的别名,比如int,String,八大基本类型都是
58 我们也可以自定义别名,
59 com.wuhao.mybatis.domain.User 使用别名 user 代替
60 -->
61 <typeAliases>
62 <!-- 单个定义别名 -->
63 <typeAlias type="com.wuhao.mybatis.domain.User" alias="user"/>
64 <!-- 批量定义别名(推荐)
65 指定批量定义别名的类包,在此包下的所有类都将可以使用别名,别名就为类名(首字母大小写都可以)
66 -->
67 <!-- <package name="com.wuhao.mybatis.domain"/> -->
68 </typeAliases>
69
70 <!-- 类型转换器,将数据库的类型转换成java的类型,
71 mybatis会帮我们做这个事情,我们不需要自己设置,
72 <typeHandlers></typeHandlers>
73 -->
74
75 <!--
76 对象工厂不用管,因为到时候肯定和spring整合,都会由sprig来管理。
77 <objectFactory></objectFactory>
78 -->
79
80 <!--
81 mappers:加载映射文件
82 四种方式来加载
83 1、<mapper resource="config/sqlmap/user.xml"/>
84 使用相对路径,相对于项目底下。,比如config下的sqlmap下的user.xml
85 2、<mapper url=’’/>
86 使用绝对路径,比如d盘下的xx,不会用这种
87 3、<mapper class=’’/>
88 使用mapper接口的全县定名。就不用管路径问题了,让mybatis通过全限定名自己去找映射文件
89 前提:mapper接口的名称必须与映射文件的名称相同,并且放到一个目录下,
90 比如:UserMapper.java(接口) UserMapper.xml(映射文件)
91 4、<package name=’’/>(推荐)
92 注册指定包下的所有映射文件
93 <package name="com.wuhao.mapper"/>
94 配置了com.wuhao.mapper下的所有映射文件,
95 注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下
96 -->
97
98
99
100 <!-- 配置mybatis的环境信息 -->
101 <environments default="development">
102 <environment id="development">
103 <!-- 配置JDBC事务控制,由mybatis进行管理 -->
104 <transactionManager type="JDBC"></transactionManager>
105 <!-- 配置数据源,采用dbcp连接池 -->
106 <dataSource type="POOLED">
107 <!-- 引用db.properties中的信息,通过${} -->
108 <property name="driver" value="${db.driver}"/>
109 <property name="url" value="${db.url}"/>
110 <property name="username" value="${db.username}"/>
111 <property name="password" value="${db.password}"/>
112 </dataSource>
113 </environment>
114 </environments>
115 <!-- 加载mapper映射文件 -->
116 <mappers>
117 <!-- <mapper resource="sqlmap/User.xml"/> -->
118 <!-- 批量加载映射文件 -->
119 <package name="com.wuhao.mapper"/>
120 <package name="com.wuhao.shuru"/>
121 <package name="com.wuhao.resultMap"/>
122 <package name="com.wuhao.onetoone"/>
123 </mappers>
124 </configuration>

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 <!--
7 属性
8 <properties></properties>
9 全局参数设置
10 <settings></settings>
11 类型别名
12 <typeAliases></typeAliases>
13 类型处理器
14 <typeHandles></typeHandles>
15 对象工厂
16 <objectFactory></objectFactory>
17 插件
18 <plugins></plugins>
19 以上属性在后边会详细讲解到,现在我们就只需要关注一下下面的配置即可
20 如下所配置的就是使用这点东西。
21 environments(环境信息集合)
22 environment(单个环境信息)
23 transactionManager(事物)
24 dataSource(数据源)
25 environment
26 environments
27 mappers(映射器)
28 -->
29
30 <!--
31 properties:引用java属性文件中的配置信息
32 比如加载连接数据库的帐号密码等信息的properties配置文件。
33 使用${}可以引用已经加载的java配置文件中的信息
34 使用时注意一个问题,mybatis按照下面的顺序加载属性
35 1、properties标签体内的属性
36 2、properties引用的属性会被读取,本例中也就是db.properties中的属性(key-value),
37 如果发现db.properties中有和第一步加载的属性的key相同的属性,那么将其覆盖
38 3、parameterType:接收的值最后被读取,parameterType="int" int相当于key,而实际上接收到的值
39 为value,如果parameterType的属性名与前面两步中的属性名相同,那么将其覆盖。
40 总结:加载的越快,就很有可能被覆盖,所以在properties中的key值都使用db.xxx,目的就是防止重名被覆盖
41 -->
42 <properties resource="db.properties">
43 <!-- 这里就是properties标签体内的属性
44 比如: <property name="" value=""/>
45 -->
46 </properties>
47
48 <!-- setting 全局参数,比如懒加载、是否启动缓存机制-->
49 <!-- <settings>
50 打开延迟加载的开关,默认为true
51 <setting name="lazyLoadingEnabled" value="true"/>
52 积极的懒加载,默认是true,设置为false时,懒加载生效
53 <setting name="aggressiveLazyLoading" value="false"/>
54 </settings> -->
55
56 <!-- typeAliases:别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int,
57 而不需要在编写全限定名 java.lang.Integer了。 有很多默认的别名,比如int,String,八大基本类型都是
58 我们也可以自定义别名,
59 com.wuhao.mybatis.domain.User 使用别名 user 代替
60 -->
61 <typeAliases>
62 <!-- 单个定义别名 -->
63 <typeAlias type="com.wuhao.mybatis.domain.User" alias="user"/>
64 <!-- 批量定义别名(推荐)
65 指定批量定义别名的类包,在此包下的所有类都将可以使用别名,别名就为类名(首字母大小写都可以)
66 -->
67 <!-- <package name="com.wuhao.mybatis.domain"/> -->
68 </typeAliases>
69
70 <!-- 类型转换器,将数据库的类型转换成java的类型,
71 mybatis会帮我们做这个事情,我们不需要自己设置,
72 <typeHandlers></typeHandlers>
73 -->
74
75 <!--
76 对象工厂不用管,因为到时候肯定和spring整合,都会由sprig来管理。
77 <objectFactory></objectFactory>
78 -->
79
80 <!--
81 mappers:加载映射文件
82 四种方式来加载
83 1、<mapper resource="config/sqlmap/user.xml"/>
84 使用相对路径,相对于项目底下。,比如config下的sqlmap下的user.xml
85 2、<mapper url=’’/>
86 使用绝对路径,比如d盘下的xx,不会用这种
87 3、<mapper class=’’/>
88 使用mapper接口的全县定名。就不用管路径问题了,让mybatis通过全限定名自己去找映射文件
89 前提:mapper接口的名称必须与映射文件的名称相同,并且放到一个目录下,
90 比如:UserMapper.java(接口) UserMapper.xml(映射文件)
91 4、<package name=’’/>(推荐)
92 注册指定包下的所有映射文件
93 <package name="com.wuhao.mapper"/>
94 配置了com.wuhao.mapper下的所有映射文件,
95 注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下
96 -->
97
98
99
100 <!-- 配置mybatis的环境信息 -->
101 <environments default="development">
102 <environment id="development">
103 <!-- 配置JDBC事务控制,由mybatis进行管理 -->
104 <transactionManager type="JDBC"></transactionManager>
105 <!-- 配置数据源,采用dbcp连接池 -->
106 <dataSource type="POOLED">
107 <!-- 引用db.properties中的信息,通过${} -->
108 <property name="driver" value="${db.driver}"/>
109 <property name="url" value="${db.url}"/>
110 <property name="username" value="${db.username}"/>
111 <property name="password" value="${db.password}"/>
112 </dataSource>
113 </environment>
114 </environments>
115 <!-- 加载mapper映射文件 -->
116 <mappers>
117 <!-- <mapper resource="sqlmap/User.xml"/> -->
118 <!-- 批量加载映射文件 -->
119 <package name="com.wuhao.mapper"/>
120 <package name="com.wuhao.shuru"/>
121 <package name="com.wuhao.resultMap"/>
122 <package name="com.wuhao.onetoone"/>
123 </mappers>
124 </configuration>

九、总结
以上就把全局配置文件中的内容全部给讲解了一遍,其中
没有具体讲解这个,因为都是死东西,在前一章节都是使用这个,所以就不在过多分析,其他的都有讲解到是什么作用,现在应该对前面一章的东西有更加深入的理解,但是需要彻底理解,还需要等待下一章讲解映射文件之后才能够更加清晰。加油。
Mybatis学习(二)————— 全局配置文件详解的更多相关文章
- Mybatis(二) 全局配置文件详解
这节来说说全局配置文件的东西,非常简单.看一遍就懂了. --WH 一.全部配置内容 SqlMapConfig.xml的配置内容和顺序如下,顺序不能乱.现在来对这些属性的意思一一进行讲解. 二.prop ...
- mybatis学习二 全局配置文件常用配置
全局配置文件的详细解析可以参考mybatis的中文参考文档 1.全局配置文件中内容1.1 <transactionManager/> type 属性可取值1.1.1 JDBC,事务管理使用 ...
- MyBatis 全局配置文件详解(七)
MyBatis 配置文件作用 MyBatis配置文件包含影响 MyBatis 框架正常使用的功能设置和属性信息.它的作用好比手机里的设置图标,点击这个图标就可以帮助我们查看手机的属性信息和设置功能.其 ...
- 2017.2.9 深入浅出MyBatis技术原理与实践-第八章 MyBatis-Spring(二)-----配置文件详解
深入浅出MyBatis技术原理与实践-第八章 MyBatis-Spring(二) ------配置文件详解 8.2 MyBatis-Spring应用 8.2.1 概述 本文主要讲述通过注解配置MyBa ...
- Linux学习之用户配置文件详解(十四)
Linux学习之用户配置文件详解 目录 用户信息文件/etc/password 影子文件/etc/shadow 组信息文件/etc/group 组密码文件/etc/gshadow 用户信息文件/etc ...
- Mybatis全局配置文件详解(三)
每个基于Mybatis应用都是以一个SqlSessionFactory实例为中心.SqlSessionFactory实例可以由SqlSessionFactoryBuild获得,而SqlSessionF ...
- MyBatis系列:二、配置文件详解
本文会详细介绍MyBatis的常用配置 1.properties节点 <properties resource="mybatis-config.properties"> ...
- Mybatis Generator生成工具配置文件详解
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration ...
- Tomcat学习(二)------Tomcat原理详解及请求过程
Tomcat: Tomcat是一个JSP/Servlet容器.其作为Servlet容器,有三种工作模式:独立的Servlet容器.进程内的Servlet容器和进程外的Servlet容器. Tomcat ...
随机推荐
- python 实现rsa 的加密解密存读取(PEM格式证书)【转发】
来源:CSDN 原文:https://blog.csdn.net/sjt1996/article/details/83377800
- 导出mysql的表格内容到txt文件
操作流程: $ mysql -uroot -p mysql> use foo; mysql> select * from userinfo into outfile '/var/lib/m ...
- squid 正向代理 简单配置
linux 正向同步 项目上web服务器不给访问外网,迁移服务器环境又太麻烦,决定给web服务器做正向代理,刚开始使用nginx,但是https代理一直不成功,后面大佬建议使用squid来达到相同目的 ...
- 初识大数据(二. Hadoop是什么)
hadoop是一个由Apache基金会所发布的用于大规模集群上的分布式系统并行编程基础框架.目前已经是大数据领域最流行的开发架构.并且已经从HDFS.MapReduce.Hbase三大核心组件成长为一 ...
- Office Web addin 踩坑计:替换后台网站为MVC框架时遇到的问题
Office Web Addin 模板程序的后台本质上是一个网站,你在调试的时候可以发现它的进程是一个32位的IE进程 所以可以把它替换成Asp.net的网站. 替换方法: 1.点击WordRevie ...
- 网站模仿——LOFTER个人主页
代码片段 码云链接:https://gitee.com/gulveig/codes/e7q95kub6clvxt2ydi84g83
- ES6中的箭头函数和普通函数有什么区别?
1.普通函数中的this总是指向调用它的那个对象, 箭头函数没有自己的this,他的this永远指向其定义环境,任何方法都改变不了其指向,如call().bind().apply().(正是因为它没有 ...
- Maven 在新版eclipse报错的解决
转自Stack Overflow Remove all your failed downloads: Linux: find ~/.m2 -name "*.lastUpdated" ...
- Tinkoff Challenge - Final Round (Codeforces Round #414, rated, Div. 1 + Div. 2)
A: 思路:就是找b,c之前有多个s[i] 代码: #include<stdio.h>#define ll long longusing namespace std;ll a,b,c;in ...
- linux之配置Mongodb~
OK 让我们先下载一波mongodb~(64位ubuntu) curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0. ...