欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Mybatis中的config.xml配置文件详细解析

程序员文章站 2023-12-02 20:23:34
经过前面的文章,我觉得对mybatis的正题理解已经足够了,但是对mybatis的使用,我觉得还是会有一点的模糊,就我个人而言,我觉得掌握好mybatis框架,主要要明白三...

经过前面的文章,我觉得对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" /> 
[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配置文件详细解析,希望对大家有所帮助