整合MyBatis配置
寻找starter
SpringBoot官方的Starter:spring-boot-starter-*
第三方的: *-spring-boot-starter
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.2.2</version>
</dependency>
配置模式
- 全局配置文件
- SqlSessionFactory : 自动配置好了
- SqlSession:自动配置了 SqlSessionTemplate 组合了 SqlSession
- @Import({MybatisAutoConfiguration.AutoConfiguredMapperScannerRegistrar.class})
- Mapper: 只要我们写的操作MyBatis的接口标注了 @Mapper 就会被自动扫描进来
@Configuration
@ConditionalOnClass({SqlSessionFactory.class, SqlSessionFactoryBean.class})
@ConditionalOnSingleCandidate(DataSource.class)
@EnableConfigurationProperties({MybatisProperties.class}) //mybatis配置项绑定类
@AutoConfigureAfter({DataSourceAutoConfiguration.class, MybatisLanguageDriverAutoConfiguration.class})
public class MybatisAutoConfiguration implements InitializingBean {}
@ConfigurationProperties(prefix = "mybatis")
public class MybatisProperties {}
可以修改配置文件中 mybatis 开始的所有配置项
#配置mybatis规则
mybatis:
config-location: classpath:mybatis/mybatis-config.xml #全局配置文件位置
mapper-locations: classpath:mybatis/mapper/* #sql映射文件位置
先声明xxxMapper接口,再绑定xxxMapper.xml
@Mapper
public interface AccountMapper {
public Account getAccount(Long id);
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.atguigu.boot2.mapper.AccountMapper">
<select id="getAccount" resultType="com.atguigu.boot2.bean.Account">
select * from t_account where id = #{id}
</select>
</mapper>
配置 private Configuration configuration;即在配置文件中配置mybatis.configuration下面的所有,相当于改mybatis-config.xml全局配置文件中的值
@ConfigurationProperties(prefix = "mybatis")
public class MybatisProperties {
public static final String MYBATIS_PREFIX = "mybatis";
@NestedConfigurationProperty
private Configuration configuration;
}
#配置mybatis规则,如果使用configuration全局配置文件配置项,那么就不能使用config-location全局配置文件,二者选一
mybatis:
# config-location: classpath:mybatis/mybatis-config.xml #全局配置文件位置
mapper-locations: classpath:mybatis/mapper/* #sql映射文件位置
configuration: #指定mybatis全局文件中配置项的相关配置项
map-underscore-to-camel-case: true
总结
第一步:导入mybatis官方的starter
第二步:编写mapper接口,并且标注@Mapper注解
第三步:编写sql映射文件并绑定到mapper接口
第四步:在application.yml指定Mapper文件的位置,也可以指定全局配置文件的信息(建议配置mybatis.configuration标签下配置全部文件的配置项)