配置解析
1.核心配置文件
-
mybatis-config.xml
-
Mybatis的配置文件包含了会深深影响Mybatis行为的设置和属性信息。
configuration(配置)
properties(属性)
settings(设置)
typeAliases(类型别名)
typeHandlers(类型处理器)
objectFactory(对象工厂)
plugins(插件)
environments(环境配置)
environment(环境变量)
transactionManager(事务管理器)
dataSource(数据源)
databaseIdProvider(数据库厂商标识)
mappers(映射器)
2.环境变量(environment)
- MyBatis 可以配置成适应多种环境
- 不过要记住:尽管可以配置多个环境,但每个 SqlSessionFactory 实例只能选择一种环境。
- mybatis默认的事务管理器时;JDBC,连接池:POOLED
3.属性(properties)
我们可以通过properties属性来实现引用配置文件
这些属性可以在外部进行配置,并可以进行动态替换。你既可以在典型的 Java 属性文件中配置这些属性,也可以在 properties 元素的子元素中设置。【db.properties】
driver=com.musql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?serverTimezone=UTC
username=root
password=123456
在核心配置文件中引入
编写配置文件
db.properties
driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?serverTimezone=UTC
username=root
password=123456
在核心配置文件mybatis-config中映入
</properties>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<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>
- 可以直接引入外部文件
- 可以在其中增加一些属性配置
- 如果两个文件有同一个字段,写读取外部文件
4.类别名
- 类型别名可为 Java 类型设置一个缩写名字
- 存在的意思仅在用于减少类完全限定名的冗余。
<!--可以给实体类写别名-->
<typeAliases>
<typeAlias type="com.zhou.pojo.User" alias="User"/>
</typeAliases>
-
也可以指定一个包名,Mybatis回包含下面搜索需要的java bean,
比如:扫描实体类的包,它的默认别名就是这个类的类名,首字母小写
<!--可以给实体类写别名-->
<typeAliases>
<package name="com.zhou.pojo"/>
</typeAliases>
- 在实体类比较少的时候使用第一种,反之使用第二种
- 第一种可以自定义别名,第二种则需要系统一点的,如果有需要,可以在实体类前面使用注解
@Alias("user")
5.设置
-
这是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为
-
日志实现
logImpl 指定 MyBatis 所用日志的具体实现,未指定时将自动查找。 SLF4J | LOG4J | LOG4J2 | JDK_LOGGING | COMMONS_LOGGING | STDOUT_LOGGING | NO_LOGGING 未设置 lazyLoadingEnabled 延迟加载的全局开关。当开启时,所有关联对象都会延迟加载。 特定关联关系中可通过设置 fetchType
属性来覆盖该项的开关状态。true | false false cacheEnabled 全局性地开启或关闭所有映射器配置文件中已配置的任何缓存。 true | false true -
汇总
<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其他
typeHandlers(类型处理器)
objectFactory(对象工厂)
plugins(插件)
-mybatis-generator-core
-mybatis-plus
-通用mapper
7映射器
MapperRegistry:注册绑定我们的映射器
方法一:
要用/
<mappers>
<mapper resource="com/zhou/dao/UserMapper.xml"/>
</mappers>
方法二:
可能会出现一些问题,持久层里面,映射和映射文件名字一致,且在用一个包下面
<mappers>
<mapper class="com.zhou.dao.UserMapper"/>
</mappers>
方法三:
与方法二有同样的问题
<mappers>
<package name="com.zhou.dao"/>
</mappers>
总结
- 将数据库配置文件外部引入
- 实体类别名
- 保证UserMapper接口和UserMapper.xml改为一致,并在用一个包下面!