经过前面的文章,我觉得对Mybatis的正题理解已经足够了,但是对Mybatis的使用,我觉得还是会有一点的模糊,就我个人而言,我觉得掌握好Mybatis框架,主要要明白三个文件,第一个就是等下要谈论的Mybatis-comfig.xml文件,还有就是**Mapper.xml,以及我们所定义的Mapper类,理解了这三个东西,然后有sql的基础,还有java的基础的话,后面不论是使用基于xml的方法,还是基于java-based Configuration的方法,都会简单的多。
废话不多说,现在就一起来理解一下第一个重要的文件:Mybatis-config.xml文件。
首先我们来看一下,一个空白的完整的Mybatis-config.xml文件(这个名字可以自由操作,必须要记住这个是Mybatis配置文件就行)
可以直接创建一个空白的xml文件,然后上去官网复制一份头文件,粘贴进来
1
2
3
4
5
|
<?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> </configuration |
上面这个就是基本的Mybatis-config.xml文件,我们在开发中需要添加我们需要的配置,下面就给出一个加上了基本的配置文件,通过这个来说:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
<?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> <typeAliases> <typeAlias alias= "Student" type= "com.mybatis3.domain.Student" /> </typeAliases> <environments default = "development" > <environment id= "development" > <transactionManager type= "JDBC" /> <dataSource type= "POOLED" > <property name= "driver" value= "com.mysql.jdbc.Driver" /> <property name= "url" value= "jdbc:mysql://localhost:3306/test" /> <property name= "username" value= "root" /> <property name= "password" value= "admin" /> </dataSource> </environment> </environments> <mappers> <mapper resource= "com/mybatis3/mappers/StudentMapper.xml" /> </mappers> </configuration> |
从上面的内容里面我们可以看见的标签有下面这些,但是这些是什么意思呢?
<configuration>:声明在标签里面的信息是配置信息
<typeAliases>:声明在该标签里面的信息是一个个的别名
<typealias>:声明要使用别名的对象(全路径)用java注解的话可以使用@Alias注解声明
<environments>:声明在该标签内的环境变量,default表示默认的环境变量,一个environment表示一个jdbc连接数据库,如果有很多数据库的话我们要用到不同的环境变量
<environment>:声明环境变量
<transactionManager>:声明事务管理器 它的类型(type)有:JDBC(基于jdbc的事务) 还有 MANAGED(托管的事务)
<dataSource>:声明数据源,数据源的类型有NOPOOLED ,POOLED ,还有JIDN,在数据量少的话用ONPOOLED,测试和开发过程一般用POOLED,实际运行使用JIDN
<property>:jdbc连接的一些属性
<mappers>:声明我们定义的一个个Mapper类,或者说是关联
<mapper>:声明Mapper的路径
上面说到的都是在使用Mybatis要使用到的基本标签,必须要掌握,可能不明白上面那个environments的使用,怎么去获取一个environment,下面看看一个例子来:
1
2
3
4
5
|
InputStream in = Resource.getResourceAsInputSteam("mybatis.config"); //定义默认environment defaultSqlSessionFactory = new SqlSessionFactoryBuilder().build(in); //其他的environment otherSqlSessionFactory = new SqlSessionFactoryBuilder().build(in, "environment的ID"); |
上面的defaultSqlSessionFactory要自己声明(注意)
那么除了上面的标签之外还有哪些标签呢?下面在一个看看比较常用的其他标签
<Settings>:声明一些全局变量的
<properties>:声明属性文件的key和value,但是如果使用了.properties文件将会被覆盖。
<typeHandlers>:自定义我们的传入参数类型处理器,需要extends BaseTypeHandler<自定义响应的类型>
最后再来看看Mybatis默认的setting配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<setting name= "cacheEnabled" value= "true" /> //是否使用缓存 <setting name= "lazyLoadingEnabled" value= "true" /> //是否是懒记载 <setting name= "multipleResultSetsEnabled" value= "true" /> <setting name= "useColumnLabel" value= "true" /> <setting name= "useGeneratedKeys" value= "false" /> <setting name= "autoMappingBehavior" value= "PARTIAL" /> <setting name= "defaultExecutorType" value= "SIMPLE" /> <setting name= "defaultStatementTimeout" value= "25000" /> <setting name= "safeRowBoundsEnabled" value= "false" /> <setting name= "mapUnderscoreToCamelCase" value= "false" /> [java] view plain copy <setting name= "localCacheScope" value= "SESSION" /> <setting name= "jdbcTypeForNull" value= "OTHER" /> <setting name= "lazyLoadTriggerMethods" value= "equals,clone,hashCode ,toString" /> |
总结
以上所述是小编给大家介绍的Mybatis中的config.xml配置文件详细解析,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:http://blog.csdn.net/YQYnsmile/article/details/52807815