SpringBoot 整合MyBatis配置-配置模式导入starter依赖

本文介绍了如何在SpringBoot中集成MyBatis,包括引入mybatis-spring-boot-starter,配置全局与局部设置,使用@Mapper注解扫描接口,以及编写mapper接口和映射文件。详细步骤包括导入依赖、编写接口和XML文件、配置YAML文件等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

整合MyBatis配置

https://github.com/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标签下配置全部文件的配置项)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值