1.核心配置文件
- mybatis-config.xml
- MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息。
- configuration(配置)
properties(属性)
settings(设置)
typeAliases(类型别名)
typeHandlers(类型处理器)
objectFactory(对象工厂)
plugins(插件)
environments(环境配置)
environment(环境变量)
transactionManager(事务管理器)
dataSource(数据源)
databaseIdProvider(数据库厂商标识)
mappers(映射器)
2.环境变量(environments)
- MyBatis 可以配置成适应多种环境
- 尽管可以配置多个环境,但每个 SqlSessionFactory 实例只能选择一种环境。
<environments default="test">
<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/mybatis?useSSl=true&useUnicode=true&characterEncoding=UTF-8"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
<environment id="test">
<transactionManager type="JDBC">
</transactionManager>
<!-- 连接数据库 dbcp c3p0 -->
<!-- type="POOLED|UNPOOLED|JNDI"-->
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
3.属性(properties)
- 我们可以使用properties属性引入外部配置文件
- 这些属性都是可外部配置且可动态替换的,既可以在典型的 Java 属性文件中配置,亦可通过 properties 元素的子元素来传递。
<properties resource="db.properties"/>
之后在工程里创建db.properties
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSl=true&;useUnicode=true&;characterEncoding=UTF-8
username=root
password=root
然后其中的属性就可以在整个配置文件中被用来替换需要动态配置的属性值。
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
4.类型别名(typeAliases)
- 类型别名是为 Java 类型设置一个短的名字。
- 它只和 XML 配置有关,存在的意义仅在于用来减少类完全限定名的冗余。
<!-- 可以给实体类起别名-->
<typeAliases>
<typeAlias alias="User" type="com.zengwen.pojo.User"/>
</typeAliases>
- 也可以指定一个包名,MyBatis 会在包名下面搜索需要的 Java Bean
- 扫描实体类的把,它的默认别名就是这个类的类名,首字母小写。
<typeAliases>
<package name="com.zengwen.pojo"/>
</typeAliases>
- 在实体类比较少的时候,使用第一种方式
- 在实体类多的时候,使用第二种方式
- 第一种可以DIY别名,第二种则不行,如果非要改,就需要在实体类上添加注解
@Alias("user")
public class User {
......
}
5.设置(settings)
- 这是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为。
<settings>
<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="autoMappingUnknownColumnBehavior" value="WARNING"/>
<setting name="defaultExecutorType" value="SIMPLE"/>
<setting name="defaultStatementTimeout" value="25"/>
<setting name="defaultFetchSize" value="100"/>
<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"/>
</settings>
6.映射器(mappers)
- 每一个mapper.xml文件都需要在Mybatis核心配置文件中注册。
1.方式一: 使用相对于类路径的资源引用【推荐使用】
<mappers>
<mapper resource="com/zengwen/mapper/UserMapper.xml"/>
</mappers>
2.方式二:使用映射器接口实现类的完全限定类名
<mappers>
<mapper class="com.zengwen.mapper.UserMapper"/>
</mappers>
注意点:
- 接口和他的Mapper配置文件必须同名!
- 接口和他的Mapper配置文件必须在同一个包下!
3. 方式三:将包内的映射器接口实现全部注册为映射器
<mappers>
<package name="com.zengwen.mapper"/>
</mappers>
注意点:
- 接口和他的Mapper配置文件必须同名!
- 接口和他的Mapper配置文件必须在同一个包下!
7.其他配置
【不太重要】
- typeHandlers(类型处理器)
- objectFactory(对象工厂)
- plugins(插件)
:mybatis-generator-core
:mybatis-plus
:通用mapper