0


Spring Boot MyBatis Plus 配置数据源详解

文章目录

在这里插入图片描述

🎉欢迎来到架构设计专栏~Spring Boot MyBatis Plus 配置数据源详解


  • ☆* o(≧▽≦)o *☆嗨~我是IT·陈寒🍹
  • ✨博客主页:IT·陈寒的博客
  • 🎈该系列文章专栏:架构设计
  • 📜其他专栏:Java学习路线 Java面试技巧 Java实战项目 AIGC人工智能 数据结构学习
  • 🍹文章作者技术和水平有限,如果文中出现错误,希望大家能指正🙏
  • 📜 欢迎大家关注! ❤️

Spring Boot与MyBatis Plus的结合,为Java开发者提供了一种简便而高效的持久化解决方案。其中,数据源配置是整合过程中的重要一环。本文将深入探讨如何在Spring Boot项目中配置MyBatis Plus所使用的数据源,以及一些相关的拓展和分析。

在这里插入图片描述

1. 引入 MyBatis Plus 依赖

首先,在

pom.xml

中引入MyBatis Plus的相关依赖:

<!-- MyBatis Plus --><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.3.1</version></dependency>

这个依赖将自动导入MyBatis Plus所需的其他依赖,简化了项目的配置。

2. 数据源配置

在Spring Boot中,数据源的配置通常位于

application.properties

application.yml

文件中。下面是一个简单的数据源配置示例:

# 数据源配置
spring.datasource.url=jdbc:mysql://localhost:3306/mydatabase
spring.datasource.username=root
spring.datasource.password=password
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

# 连接池配置(可选)
spring.datasource.hikari.maximum-pool-size=10

在这个配置中,我们指定了数据库的URL、用户名、密码和驱动类。如果你希望使用连接池,可以添加连接池的相关配置,这里以Hikari连接池为例。

3. MyBatis Plus 配置

MyBatis Plus的配置通常需要继承

MybatisPlusConfigurerAdapter

类,并通过

@Configuration

注解标记为配置类。以下是一个简单的配置示例:

importcom.baomidou.mybatisplus.annotation.DbType;importcom.baomidou.mybatisplus.core.MybatisConfiguration;importcom.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;importcom.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean;importorg.apache.ibatis.plugin.Interceptor;importorg.apache.ibatis.session.SqlSessionFactory;importorg.mybatis.spring.annotation.MapperScan;importorg.springframework.context.annotation.Bean;importorg.springframework.context.annotation.Configuration;importorg.springframework.core.io.DefaultResourceLoader;importorg.springframework.core.io.support.PathMatchingResourcePatternResolver;importjavax.sql.DataSource;@Configuration@MapperScan("com.example.mapper")// 扫描 Mapper 接口所在的包publicclassMybatisPlusConfig{@BeanpublicMybatisSqlSessionFactoryBeanmybatisSqlSessionFactoryBean(DataSource dataSource)throwsException{MybatisSqlSessionFactoryBean sessionFactoryBean =newMybatisSqlSessionFactoryBean();
        sessionFactoryBean.setDataSource(dataSource);
        sessionFactoryBean.setMapperLocations(newPathMatchingResourcePatternResolver().getResources("classpath:/mapper/*.xml"));
        sessionFactoryBean.setConfiguration(mybatisConfiguration());
        sessionFactoryBean.setPlugins(newInterceptor[]{paginationInterceptor()});return sessionFactoryBean;}@BeanpublicPaginationInterceptorpaginationInterceptor(){returnnewPaginationInterceptor();}privateMybatisConfigurationmybatisConfiguration(){MybatisConfiguration configuration =newMybatisConfiguration();
        configuration.setMapUnderscoreToCamelCase(true);
        configuration.setCacheEnabled(false);return configuration;}}

在这个配置类中,我们使用

@MapperScan

注解指定了Mapper接口的扫描路径,并通过

@Bean

注解配置了

MybatisSqlSessionFactoryBean

。此外,我们还配置了分页插件

PaginationInterceptor

以及一些MyBatis的基本配置,比如下划线转驼峰、关闭缓存等。

4. 动态数据源配置(多数据源)

在一些复杂的项目中,可能需要配置多个数据源以满足不同业务需求。Spring Boot通过

AbstractRoutingDataSource

提供了动态数据源的支持。以下是一个简单的多数据源配置示例:

importorg.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;importjavax.sql.DataSource;importjava.util.HashMap;importjava.util.Map;publicclassDynamicDataSourceextendsAbstractRoutingDataSource{privatestaticfinalThreadLocal<String>CONTEXT_HOLDER=newThreadLocal<>();publicDynamicDataSource(DataSource defaultDataSource,Map<Object,Object> targetDataSources){super.setDefaultTargetDataSource(defaultDataSource);super.setTargetDataSources(newHashMap<>(targetDataSources));super.afterPropertiesSet();}publicstaticvoidsetDataSource(String dataSourceKey){CONTEXT_HOLDER.set(dataSourceKey);}publicstaticStringgetDataSource(){returnCONTEXT_HOLDER.get();}publicstaticvoidclearDataSource(){CONTEXT_HOLDER.remove();}@OverrideprotectedObjectdetermineCurrentLookupKey(){returngetDataSource();}}

上述代码中,我们继承了

AbstractRoutingDataSource

,并通过

ThreadLocal

来保存当前数据源的key。在具体的业务中,通过调用

DynamicDataSource.setDataSource("dataSourceKey")

来切换数据源。

5. 小结

通过以上步骤,我们完成了在Spring Boot项目中配置MyBatis Plus数据源的过程。首先引入MyBatis Plus的相关依赖,然后在

application.properties

application.yml

中配置数据源,接着通过一个配置类进行MyBatis Plus的相关配置。最后,如果需要多数据源支持,可以使用

AbstractRoutingDataSource

实现动态数据源的切换。

在这里插入图片描述

在实际项目中,根据具体的业务需求,可能还需要更详细的配置和优化。希望本文的内容对你在Spring Boot项目中使用MyBatis Plus提供一些帮助。


🧸结尾 ❤️ 感谢您的支持和鼓励! 😊🙏
📜您可能感兴趣的内容:

  • 【Java面试技巧】Java面试八股文 - 掌握面试必备知识(目录篇)
  • 【Java学习路线】2023年完整版Java学习路线图
  • 【AIGC人工智能】Chat GPT是什么,初学者怎么使用Chat GPT,需要注意些什么
  • 【Java实战项目】SpringBoot+SSM实战:打造高效便捷的企业级Java外卖订购系统
  • 【数据结构学习】从零起步:学习数据结构的完整路径

在这里插入图片描述


本文转载自: https://blog.csdn.net/qq_43546721/article/details/134395229
版权归原作者 IT·陈寒 所有, 如有侵权,请联系我们删除。

“Spring Boot MyBatis Plus 配置数据源详解”的评论:

还没有评论