基于SpringBoot的完成mybatis整合

Posted 黑马程序员官方

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了基于SpringBoot的完成mybatis整合相关的知识,希望对你有一定的参考价值。

SpringBoot

🍌掌握基于SpringBoot框架的程序开发步骤
🍌使用SpringBoot配置信息修改服务器配置
🍌SpringBoot完成SSM整合之SpringBoot整合junit

今日目标:

  • 基于SpringBoot的完成mybatis整合

一、SpringBoot整合mybatis

1.1 回顾Spring整合Mybatis

Spring 整合 Mybatis 需要定义很多配置类

  • SpringConfig 配置类

    • 导入 JdbcConfig 配置类

    • 导入 MybatisConfig 配置类

      @Configuration
      @ComponentScan("com.itheima")
      @PropertySource("classpath:jdbc.properties")
      @Import(JdbcConfig.class,MyBatisConfig.class)
      public class SpringConfig 
      
      
      
  • JdbcConfig 配置类

  • 定义数据源(加载properties配置项:driver、url、username、password)

    public class JdbcConfig 
        @Value("$jdbc.driver")
        private String driver;
        @Value("$jdbc.url")
        private String url;
        @Value("$jdbc.username")
        private String userName;
        @Value("$jdbc.password")
        private String password;
    
        @Bean
        public DataSource getDataSource()
            DruidDataSource ds = new DruidDataSource();
            ds.setDriverClassName(driver);
            ds.setUrl(url);
            ds.setUsername(userName);
            ds.setPassword(password);
            return ds;
        
    
    
  • MybatisConfig 配置类

    • 定义 SqlSessionFactoryBean

    • 定义映射配置

      @Bean
      public MapperScannerConfigurer getMapperScannerConfigurer()
          MapperScannerConfigurer msc = new MapperScannerConfigurer();
          msc.setBasePackage("com.itheima.dao");
          return msc;
      
      
      @Bean
      public SqlSessionFactoryBean getSqlSessionFactoryBean(DataSource dataSource)
          SqlSessionFactoryBean ssfb = new SqlSessionFactoryBean();
          ssfb.setTypeAliasesPackage("com.itheima.domain");
          ssfb.setDataSource(dataSource);
          return ssfb;
      
      
      

1.2 SpringBoot整合mybatis

1.2.1 创建模块

  • 创建新模块,选择 Spring Initializr,并配置模块相关基础信息

  • 选择当前模块需要使用的技术集(MyBatis、mysql

1.2.2 定义实体类

com.itheima.domain 包下定义实体类 Book,内容如下

public class Book 
    private Integer id;
    private String name;
    private String type;
    private String description;
    
    //setter and  getter
    
    //toString

1.2.3 定义dao接口

com.itheima.dao 包下定义 BookDao 接口,内容如下

public interface BookDao 
    @Select("select * from tbl_book where id = #id")
    public Book getById(Integer id);

1.2.4 定义测试类

test/java 下定义包 com.itheima ,在该包下测试类,内容如下

@SpringBootTest
class Springboot08MybatisApplicationTests 

	@Autowired
	private BookDao bookDao;

	@Test
	void testGetById() 
		Book book = bookDao.getById(1);
		System.out.println(book);
	

1.2.5 编写配置

我们代码中并没有指定连接哪儿个数据库,用户名是什么,密码是什么。所以这部分需要在 SpringBoot 的配置文件中进行配合。

application.yml 配置文件中配置如下内容

spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/ssm_db
    username: root
    password: root

1.2.6 测试

运行测试方法,我们会看到如下错误信息

错误信息显示在 Spring 容器中没有 BookDao 类型的 bean。为什么会出现这种情况呢?

原因是 Mybatis 会扫描接口并创建接口的代码对象交给 Spring 管理,但是现在并没有告诉 Mybatis 哪个是 dao 接口。而我们要解决这个问题需要在BookDao 接口上使用 @MapperBookDao 接口改进为

@Mapper
public interface BookDao 
    @Select("select * from tbl_book where id = #id")
    public Book getById(Integer id);

注意:

SpringBoot 版本低于2.4.3(不含),Mysql驱动版本大于8.0时,需要在url连接串中配置时区 jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTC,或在MySQL数据库端配置时区解决此问题

1.2.7 使用Druid数据源

现在我们并没有指定数据源,SpringBoot 有默认的数据源,我们也可以指定使用 Druid 数据源,按照以下步骤实现

  • 导入 Druid 依赖

    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>druid</artifactId>
        <version>1.1.16</version>
    </dependency>
    
  • application.yml 配置文件配置

    可以通过 spring.datasource.type 来配置使用什么数据源。配置文件内容可以改进为

    spring:
      datasource:
        driver-class-name: com.mysql.cj.jdbc.Driver
        url: jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTC
        username: root
        password: root
        type: com.alibaba.druid.pool.DruidDataSource
    

以上是关于基于SpringBoot的完成mybatis整合的主要内容,如果未能解决你的问题,请参考以下文章

SpringBoot2基于SpringBoot实现SSMP整合

springboot之基于注解整合mybatis

spring boot整合mybitas怎么配置oracle?

SpringBoot——整合SSM(主要整合MyBatis)

SpringBoot与Mybatis整合实例详解

SpringBoot14 SpringBoot整合mybatis