文章目录
详细配置可 点击此处查看官网文档
1、核心配置文件
- mybatis-config.xml
- MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息。 配置文档的顶层结构如下:
- configuration(配置)
- properties(属性)
- settings(设置)
- typeAliases(类型别名)
- typeHandlers(类型处理器)
- objectFactory(对象工厂)
- plugins(插件)
- environments(环境配置)
- environment(环境变量)
- transactionManager(事务管理器 type="[JDBC|MANAGED]")
- dataSource(数据源 type="[UNPOOLED|POOLED|JNDI]")
- environment(环境变量)
- databaseIdProvider(数据库厂商标识)
- mappers(映射器)
- configuration(配置)
2、环境配置(environments)
-
MyBatis 可以配置成适应多种环境
不过要记住:尽管可以配置多个环境,但每个SqlSessionFactory实例只能选择一种环境。
-
Mybatis默认的transactionManager(事务管理器)就是JDBC
-
Mybatis默认的dataSource(数据源)是POOLED(连接池)
3、属性(properties)
-
可以通过properties属性来实现引用配置文件
-
这些属性都是可外部配置且可动态替换的,既可以在典型的Java属性文件中配置,亦可通过properties元素的子元素来传递。【db.properties】
-
编写一个配置文件【db.properties】
driver = com.mysql.jdbc.Driver url = jdbc:mysql://localhost:3306/mybatisnote?useSSL=false&useUnicode=true&characterEncoding=UTF-8 username = root password = 123456
-
核心配置文件
<?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> <!--直接引入外部配置文件--> <properties resource="db.properties" /> <environments default="test"> <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> </configuration>
-
可在properties中增加一些属性配置
<properties resource="db.properties"> <property name="username" value="root"/> <property name="password" value="123456"/> </properties>
-
如果两个文件有同一个字段,优先使用外部配置文件的,原因如下
如果一个属性在不只一个地方进行了配置,那么,MyBatis 将按照下面的顺序来加载: 首先读取在 properties 元素体内指定的属性。然后根据 properties 元素中的 resource 属性读取类路径下属性文件,或根据 url 属性指定的路径读取属性文件,并覆盖之前读取过的同名属性。
4、类型别名(typeAliases)
-
类型别名是为Java类型设置一个短的名字。
-
存在的意义仅在于用来减少类完全限定名的冗余。
<!--第一种:可以给实体类起别名--> <typeAliases> <typeAlias type="com.ping.pojo.User" alias="User"/> </typeAliases>
-
也可以指定一个包名,MyBatis 会在包名下面搜索需要的Java Bean
-
扫描实体类的包,它的默认别名就为这个类的类名(首字母小写)
<!--第二种--> <typeAliases> <package name="com.ping.pojo"/> </typeAliases>
- 在实体类比较少的时候,使用第一种方式;如果实体类十分多,建议使用第二种
- 第一种可以自定义别名,第二种不行
- 如果非要改别名,可以在在实体上增加注解
```java
import org.apache.ibatis.type.Alias;
//第三种
@Alias("user")
public class User {}
5、设置(setting)
- 这是 MyBatis中极为重要的调整设置,它们会改变MyBatis的运行时的行为。
设置名 | 描述 | 有效值 | 默认值 |
---|---|---|---|
cacheEnabled | 全局性地开启或关闭所有映射器配置文件中已配置的任何缓存。 | true|false | true |
lazyLoadingEnabled | 延迟加载的全局开关。当开启时,所有关联对象都会延迟加载。 特定关联关系中可通过设置 fetchType 属性来覆盖该项的开关状态。 | true|false | true |
logImpl | 指定 MyBatis 所用日志的具体实现,未指定时将自动查找。 | SLF4J | LOG4J | LOG4J2 | JDK_LOGGING | COMMONS_LOGGING | STDOUT_LOGGING | NO_LOGGING | 未设置 |
6、其他配置
- typeHandlers(类型处理器)
- objectFactory(对象工厂)
- plugins(插件)
- mybatis-generator-core
- mybatis-plus
- 通用mapper
7、映射器(mappers)
-
MapperRegistry:注册绑定Mapper文件;
-
方式一:【推荐使用】
<!--每一种Mapper.xml都需要在mybatis核心配置文件中注册--> <mappers> <mapper resource="com/ping/dao/userMapper.xml"/> </mappers>
-
方式二:使用class文件绑定注册
<!--注意点: 接口和Mapper配置文件必须同名 接口和Mapper配置文件必须在同一个包下 --> <mappers> <mapper class="com.ping.dao.UserMapper" /> </mappers>
-
方式三:使用包扫描进行注册绑定
<!--注意点同方式二--> <mappers> <package name="com.ping.dao"/> </mappers>