springboot 配置DRUID数据源的方法实例分析

yizhihongxing

SpringBoot配置Druid数据源的方法实例分析

在SpringBoot中,我们可以使用Druid数据源连接数据库,本文将详细讲解如何在SpringBoot中配置Druid数据源的方法。

引入Druid依赖

在pom.xml文件中,添加Druid依赖:

<dependency>
   <groupId>com.alibaba</groupId>
   <artifactId>druid-spring-boot-starter</artifactId>
   <version>1.2.1</version>
</dependency>

application.properties配置

在application.properties中添加如下配置项:

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

# Druid数据源配置
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.filters=stat,wall,logback
spring.datasource.validation-query=SELECT 'x'
spring.datasource.maxActive=20
spring.datasource.initialSize=5
spring.datasource.minIdle=5
spring.datasource.maxWait=60000
spring.datasource.timeBetweenEvictionRunsMillis=60000
spring.datasource.minEvictableIdleTimeMillis=300000
spring.datasource.poolPreparedStatements=true
spring.datasource.maxPoolPreparedStatementPerConnectionSize=20
spring.datasource.connectionProperties=druid.stat.mergeSql=true;druid.stat.slowSqlMillis=5000

示例1:使用JdbcTemplate连接数据库

在代码中,我们可以通过JdbcTemplate来连接Druid数据源。

@Configuration
public class DataSourceConfig {

    @Bean(name = "dataSource")
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource dataSource() {
        return DruidDataSourceBuilder.create().build();
    }

    @Bean(name = "jdbcTemplate")
    public JdbcTemplate jdbcTemplate(@Qualifier("dataSource") DataSource dataSource) {
        return new JdbcTemplate(dataSource);
    }

}

注:需要使用@Configuration和@Bean注解将DruidDataSource加入到Spring中。

示例2:在MyBatis中使用Druid数据源

在MyBatis中使用Druid数据源,需要配置SqlSessionFactory和TransactionManager。

@Configuration
@MapperScan("com.example.demo.mapper")
public class DataSourceConfig {

    @Bean(name = "dataSource")
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource dataSource() {
        return DruidDataSourceBuilder.create().build();
    }

    @Bean(name = "sqlSessionFactory")
    public SqlSessionFactory sqlSessionFactory(@Qualifier("dataSource") DataSource dataSource)
            throws Exception {
        SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
        sessionFactory.setDataSource(dataSource);
        return sessionFactory.getObject();
    }

    @Bean(name = "transactionManager")
    public DataSourceTransactionManager transactionManager(@Qualifier("dataSource") DataSource dataSource) {
        return new DataSourceTransactionManager(dataSource);
    }
}

注:需要使用@Configuration和@Bean注解将DruidDataSource相关的实例加入到Spring中,并使用@MapperScan注解指定Mapper接口所在的包。

至此,我们在SpringBoot中成功配置了Druid数据源。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:springboot 配置DRUID数据源的方法实例分析 - Python技术站

(0)
上一篇 2023年5月20日
下一篇 2023年5月20日

相关文章

  • Java Lambda 表达式详解及示例代码

    Java Lambda 表达式详解及示例代码 1. 什么是 Lambda 表达式 Lambda 表达式是 Java 8 中引入的一个新特性,它可以用更简洁的方式来表示某些接口或抽象类的实现。 Lambda 表达式可以看做是匿名函数,它由三个部分组成:参数列表、箭头符号和函数体。它的基本语法如下: (parameter1, parameter2, …) -…

    Java 2023年5月26日
    00
  • java实现Composite组合模式的实例代码

    下面我将为你讲解Java实现Composite组合模式的实例代码完整攻略。在完成该过程前,我先将Composite组合模式的一些基本概念进行简单介绍。 Composite组合模式是一种结构化设计模式,用于将对象组合成树状结构,以表示“部分-整体”的层次关系。该模式使得客户端能够使用统一的接口处理单个对象以及对象组合,从而将单个对象与组合对象视为等同的对象。 …

    Java 2023年5月19日
    00
  • JavaEE账号注册模拟网站邮箱激活

    JavaEE账号注册模拟网站邮箱激活是一个常见的Web应用程序开发需求。具体实现这个功能的步骤如下: 1. 搭建Web应用程序 首先,需要搭建一个基于JavaEE的Web应用程序,这个应用程序会充当网站的后端服务器,接收客户端请求并返回数据。可以使用诸如Tomcat、Jetty等开源的Web服务器来搭建这个Web应用程序。 2. 设计数据库 建立数据库表,通…

    Java 2023年6月15日
    00
  • 浅析Mybatis Plus和Mybatis的区别

    下面就来详细讲解 “浅析Mybatis Plus和Mybatis的区别”的完整攻略。 什么是Mybatis? Mybatis 是一款基于 Java 的持久层框架,它封装了 JDBC 操作,简化了 JDBC 操作繁琐的过程,使得开发者能够将精力集中到 SQL 的编写上面。 Mybatis 的特点: 操作简单、方便,对开发者友好 灵活度高,可以定制化 SQL 提…

    Java 2023年5月20日
    00
  • 解析Linux下Varnish缓存的配置优化

    解析Linux下Varnish缓存的配置优化 Varnish是一款高性能的Web缓存程序,它能够在内存中存储分别从Web服务器和客户端接受到的HTTP数据。本文将教你如何通过在Linux下配置和优化Varnish缓存来提高网站的性能。 安装Varnish Varnish可在多个Linux发行版上运行,以下是在Ubuntu 18.04上安装Varnish的方法…

    Java 2023年6月15日
    00
  • Java Arrays.sort()用法详解

    Java Arrays.sort()用法详解 Arrays.sort()是Java中的一个标准库函数,用于对数组进行排序,它可以对任何类型的数组进行排序(例如,整型、浮点数、字符串等等),本文将对该函数的用法进行详解。 语法 Arrays.sort(array, [fromIndex], [toIndex], [comparator]) array 参数是要…

    Java 2023年5月26日
    00
  • 如何将mybatis配置到springmvc中

    如何将 MyBatis 配置到 Spring MVC 中 MyBatis 是一款非常流行的 ORM 框架,它可以帮助我们简化数据库操作。在 Spring MVC 中,我们可以将 MyBatis 配置到项目中,以便更方便地使用 MyBatis。本文将详细讲解如何将 MyBatis 配置到 Spring MVC 中,并提供两个示例说明。 配置 MyBatis 在…

    Java 2023年5月18日
    00
  • 关于struts2中Action名字的大小写问题浅谈

    下面是关于 struts2 中 Action 名字的大小写问题的攻略: 问题描述 在 struts2 的配置文件中,Action 的名字可以大小写混用,例如: <action name="Index" class="com.example.IndexAction"> <result>/index…

    Java 2023年5月20日
    00
合作推广
合作推广
分享本页
返回顶部