Mybatis---详解Mybatis-config.xml配置文件

  经过前面的两篇博文,我觉得对Mybatis的正题理解已经足够了,但是对Mybatis的使用,我觉得还是会有一点的模糊,就我个人而言,我觉得掌握好Mybatis框架,主要要明白三个文件,第一个就是等下要谈论的Mybatis-comfig.xml文件,还有就是**Mapper.xml,以及我们所定义的Mapper类,理解了这三个东西,然后有sql的基础,还有java的基础的话,后面不论是使用基于xml的方法,还是基于java-based Configuration的方法,都会简单的多。

  废话不多说,现在就一起来理解一下第一个重要的文件:Mybatis-config.xml文件。  
  首先我们来看一下,一个空白的完整的Mybatis-config.xml文件(这个名字可以自由操作,必须要记住这个是Mybatis配置文件就行)  
可以直接创建一个空白的xml文件,然后上去官网复制一份头文件,粘贴进来

<?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文件,我们在开发中需要添加我们需要的配置,下面就给出一个加上了基本的配置文件,通过这个来说:
<?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,下面看看一个例子来:

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配置:

<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" />
<setting name="localCacheScope" value="SESSION" />
<setting name="jdbcTypeForNull" value="OTHER" />
<setting name="lazyLoadTriggerMethods" value="equals,clone,hashCode ,toString" />
上面的配置一般使用默认的就好,如果业务中需要的话再修改I,这就不多说了。下一篇我将会介绍下一个重要的文件**Mapper.xml.




  • 37
    点赞
  • 130
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值