MyBatis-全局配置文件学习

对MyBatis全局配置文件的学习

引入外部文件

mybatis可以使用properties来引入外部properties配置文件的内容:

   resource:引入类路径下的资源
   url:引入网络路径或者磁盘路径下的资源

1
<properties resource="dbconfig.properties"></properties>

settings 设置

setting:用来设置每一个设置项:

   name:设置项名
   value:设置项取值

1
2
3
4
5
6
7
8
9
10
11
12
<settings>
<!-- 驼峰命名法 -->
<setting name="mapUnderscoreToCamelCase" value="true"/>
<!-- 设置字段为空时使用的JDBC的属性 -->
<setting name="jdbcTypeForNull" value="NULL"/>

<!--显示的指定每个我们需要更改的配置的值,即使他是默认的。防止版本更新带来的问题 -->
<!-- 懒加载 使用的时候才进行加载-->
<setting name="lazyLoadingEnabled" value="true"/>
<!-- 侵入延迟加载 默认true 默认将所有属性全部加载 -->
<setting name="aggressiveLazyLoading" value="false"/>
</settings>

typeAliases

别名处理器可以为我们的java类型起别名,别名不区分大小写。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<typeAliases>
<!-- 1、typeAlias:为某个java类型起别名
type:指定要起别名的类型全类名;默认别名就是类名小写
alias:指定新的别名
-->
<!-- <typeAlias type="myBatis_Study.Student" alias="stu"/> -->

<!-- 2、package:为某个包下的所有类批量起别名
name:指定包名(为当前包以及下面所有的后代包的每一个类都起一个默认别名(类名小写),)
-->
<package name="myBatis_Study"/>

<!-- 3、批量起别名的情况下,使用@Alias注解为某个类型指定新的别名 -->
</typeAliases>

environments

环境配置,mybatis可以配置多种环境 ,default指定使用某种环境。可以达到快速切换环境。
environment:配置一个具体的环境信息,必须有两个标签,id代表当前环境的唯一标识

   transactionManager:事务管理器

type:事务管理器的类型:

    JDBC(JdbcTransactionFactory)|MANAGED(ManagedTransactionFactory)

自定义事务管理器:实现TransactionFactory接口.type指定为全类名

dataSource:数据源
type:数据源类型:UNPOOLED(UnpooledDataSourceFactory)|POOLED(PooledDataSourceFactory)
|JNDI(JndiDataSourceFactory)
自定义数据源:实现DataSourceFactory接口,type是全类名

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<environments default="dev_mysql">
<environment id="dev_mysql">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</dataSource>
</environment>

<environment id="dev_oracle">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="${orcl.driver}" />
<property name="url" value="${orcl.url}" />
<property name="username" value="${orcl.username}" />
<property name="password" value="${orcl.password}" />
</dataSource>
</environment>
</environments>

databaseIdProvider

支持多数据库厂商, type=”DB_VENDOR”(VendorDatabaseIdProvider) 作用就是得到数据库厂商的标识(驱动getDatabaseProductName()),mybatis就能根据数据库厂商标识来执行不同的sql;
例如:MySQL,Oracle,SQL Server xxxx

1
2
3
4
5
6
7
8
9
10
11
12
13
<databaseIdProvider type="DB_VENDOR">
<!-- 为不同的数据库厂商起别名 -->
<property name="MySQL" value="mysql"/>
<property name="Oracle" value="oracle"/>
<property name="SQL Server" value="sqlserver"/>
</databaseIdProvider>
<!--
这里需要到MyBatis映射文件中去设置
<select id="getEmpById" resultType="myBatis_Study.Student"
databaseId="mysql"> 别名在这里起作用,下一篇讲映射文件
select * from user where id = #{id}
</select>
-->

mappers

将sql映射注册到全局配置中。
mapper:注册一个sql映射注册配置文件.
resource:引用类路径下的sql映射文件

   mybatis/mapper/EmployeeMapper.xml

url:引用网路路径或者磁盘路径下的sql映射文件

   file:///var/mappers/AuthorMapper.xml

注册接口
class:引用(注册)接口,

   1、有sql映射文件,映射文件名必须和接口同名,并且放在与接口同一目录下
   2、没有sql映射文件,所有的sql都是利用注解写在接口上

推荐:

   比较重要的,复杂的Dao接口我们来写sql映射文件
   不重要,简单的Dao接口为了开发快速可以使用注解

1
2
3
4
5
6
7
<mappers>
<!-- <mapper resource="mybatis/mapper/StudentMapper.xml"/> -->
<!-- <mapper class="mybatis.dao.StudentMapperAnnotation"/> 注解方式-->

<!-- 批量注册: -->
<package name="com.atguigu.mybatis.dao"/>
</mappers>

简单的配置文件演示

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<?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>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}" /> <!-- 这里一般交给Spring -->
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</dataSource>
</environment>
</environments>

<!-- 将我们写好的sql映射文件(StudentMapper.xml)一定要注册到全局配置文件(mybatis-config.xml)中 -->
<mappers>
<mapper resource="StudentMapper.xml" />
</mappers>
</configuration>
原创技术分享,您的支持将鼓励我继续创作
0%