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

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实现倒序读取文件功能示例分享

    下面是Java实现倒序读取文件的完整攻略,包括两条示例。 1.为什么需要实现倒序读取文件 在日常开发中,我们常常需要读取文件的内容来进行数据处理,而有时需要读取文件的倒序内容。例如,一个日志文件,我们希望能够读取文件的最后面几行内容进行分析,或者我们希望读取一个CSV文件的内容,在读取的同时将每一行数据倒序输出等等。因此,实现倒序读取文件功能具有重要的意义和…

    Java 2023年5月19日
    00
  • JAVA读取HDFS的文件数据出现乱码的解决方案

    下面我将详细讲解“JAVA读取HDFS的文件数据出现乱码的解决方案”的完整攻略。 问题描述 在使用Java程序从HDFS上读取文件数据时,有时会遇到读取文件出现乱码的问题。 原因分析 文件编码格式不同造成乱码,HDFS文件编码格式默认为UTF-8,但是有些文件格式如GBK、GB2312等其他编码格式,此时读取会出现乱码。 解决方案 方案一:使用字符编码转换 …

    Java 2023年5月20日
    00
  • java实现输出文件夹下某个格式的所有文件实例代码

    下面是详细的攻略: 1. 获取文件夹下所有文件 为了获取一个文件夹下的所有文件,我们可以使用Java中的File类和递归算法。可以先定义一个方法,传入文件夹的路径,使用该方法时传入希望查找的文件格式。 import java.io.File; public class FileUtil { /** * 获取指定文件夹下某一类型的所有文件 * * @param…

    Java 2023年5月20日
    00
  • java邮件乱码的彻底解决方案

    下面是“Java邮件乱码的彻底解决方案”的完整攻略: 1. 问题描述 在使用Java程序发送邮件时,邮件内容中的中文字符可能会出现乱码现象,特别是在收件人使用的邮件客户端接收邮件时。如何避免这个问题,保证邮件内容能够正常显示呢? 2. 解决方案 Java发送邮件的原理是通过SMTP协议将纯文本或HTML格式的内容发送到邮件服务器,然后由邮件服务器将邮件传递到…

    Java 2023年5月20日
    00
  • springboot 按月分表的实现方式

    使用SpringBoot分库分表组件的时候,要实现按月分表就需要按照下面的步骤进行配置。 步骤一:配置yml或properties文件 首先,我们需要在配置文件中设置分表相关的属性,例如: spring: sharding: tables: student: actual-data-nodes: ds$->{0..1}.student$->{20…

    Java 2023年6月3日
    00
  • SpringBoot高级配置之临时属性、配置文件、日志、多环境配置详解

    Spring Boot高级配置之临时属性、配置文件、日志、多环境配置详解 在Spring Boot应用程序中,我们需要进行高级配置,以满足不同的需求。本文将详细讲解Spring Boot高级配置,包括临时属性、配置文件、日志、多环境配置等。 临时属性 Spring Boot允许我们在运行时设置临时属性,这些属性将覆盖应用程序中的默认属性。以下是一个示例: @…

    Java 2023年5月15日
    00
  • 通过实例了解如何在JavaWeb实现文件下载

    让我来为您详细讲解如何在JavaWeb实现文件下载的完整攻略。 通过实例了解如何在JavaWeb实现文件下载 在JavaWeb中实现文件下载有多种方式,下面我们就分别来介绍一下。 方式一:使用Servlet实现文件下载 实现步骤: 1.在web.xml中配置一个Servlet,用于处理文件下载请求 <servlet> <servlet-na…

    Java 2023年5月19日
    00
  • jsp中使用javabean实例介绍

    下面是使用JavaBean实例在JSP中的介绍和示例。 什么是JavaBean JavaBean是Java平台的一种基本组件,是一种Java类,具有以下特征: 类是公共的的(即public class)。 有一个无参数的构造函数(即默认构造函数)。 类的属性(即数据成员)被私有化(即private)。 通过 getter/setter 方法来访问这些属性,属…

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