spring boot配置MySQL数据库连接、Hikari连接池和Mybatis的简单配置方法

 更新时间:2018年03月08日 11:58:54   作者:Clement-Xu  
这篇文章主要介绍了spring boot配置MySQL数据库连接、Hikari连接池和Mybatis的简单配置方法,需要的朋友可以参考下

此方法为极简配置,支持MySQL数据库多库连接、支持Hikari连接池、支持MyBatis(包括Dao类和xml文件位置的配置)。

1、pom.xml中引入依赖:

<!-- Begin of DB related --> 
 <dependency> 
  <groupId>org.mybatis.spring.boot</groupId> 
  <artifactId>mybatis-spring-boot-starter</artifactId> 
  <version>1.1.1</version> 
  <exclusions> 
   <exclusion> 
    <groupId>org.apache.tomcat</groupId> 
    <artifactId>tomcat-jdbc</artifactId> 
   </exclusion> 
  </exclusions> 
 </dependency> 
 <dependency> 
  <groupId>com.zaxxer</groupId> 
  <artifactId>HikariCP</artifactId> 
 </dependency> 
 <dependency> 
  <groupId>mysql</groupId> 
  <artifactId>mysql-connector-java</artifactId> 
 </dependency> 
<!-- End of DB related --> 

我们使用了mybatis-spring-boot-starter,并让它把tomcat-jdbc连接池排除掉,这样spring-boot就会寻找是否有HikariCP可用,第二个依赖就被找到了,然后mysql-connector也有了。

2、application.yml中的相关配置:

spring: 
 profiles: 
 active: dev 
 datasource: 
 driver-class-name: com.mysql.jdbc.Driver 
 username: root 
 password: 123456 
 hikari: 
  maxLifetime: 1765000 #一个连接的生命时长(毫秒),超时而且没被使用则被释放(retired),缺省:30分钟,建议设置比数据库超时时长少30秒以上 
  maximumPoolSize: 15 #连接池中允许的最大连接数。缺省值:10;推荐的公式:((core_count * 2) + effective_spindle_count) 
mybatis: 
 mapperLocations: classpath:mapper/*.xml 
--- 
# 开发环境配置 
spring: 
 profiles: dev 
 datasource: 
 url: jdbc:mysql://localhost:3306/ 
--- 
# 测试环境配置 
spring: 
 profiles: test 
 datasource: 
 url: jdbc:mysql://192.168.0.12:3306/ 
--- 
# 生产环境配置 
spring: 
 profiles: prod 
 datasource: 
 url: jdbc:mysql://192.168.0.13:3306/ 

其中,datasource.url最后面不跟dbName,这样就可以支持多个db的情况,使用的时候只需要在sql语句的table名前面里面指定db名字就行了。

3、Dao接口代码:

package com.xjj.dao; 
import org.apache.ibatis.annotations.Mapper; 
import org.apache.ibatis.annotations.Select; 
import com.xjj.entity.Person; 
@Mapper 
public interface PersonDAO { 
 @Select("SELECT id, first_name AS firstName, last_name AS lastName, birth_date AS birthDate, sex, phone_no AS phoneNo" 
   + " FROM test.t_person WHERE id=#{0};") 
 public Person getPersonById(int id); 
 public int insertPerson(Person person); 
 public int updatePersonById(Person person); 
 public int updatePersonByPhoneNo(Person person); 
} 

只需要用@Mapper注解,就可以支持被Mybatis找到,并支持在方法上面写SQL语句。

4、XML文件:

在resources目录下创建mapper目录,然后创建xml文件如下:

<?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.xjj.dao.PersonDAO"> 
 <!-- 插入数据库用户表 --> 
 <insert id="insertPerson"> 
  INSERT INTO test.t_person(first_name,last_name,birth_date,sex,phone_no,update_dt) 
  VALUES(#{firstName},#{lastName},#{birthDate},#{sex},#{phoneNo},NOW()) 
 </insert> 
 <update id="updatePersonById"> 
  UPDATE test.t_person SET 
   first_name=#{firstName}, last_name=#{lastName}, birth_date=#{birthDate}, sex=#{sex}, phone_no=#{phoneNo} 
  WHERE id=#{id} 
 </update> 
 <update id="updatePersonByPhoneNo"> 
  UPDATE test.t_person SET 
   first_name=#{firstName}, last_name=#{lastName}, birth_date=#{birthDate}, sex=#{sex} 
  WHERE phone_no=#{phoneNo} 
 </update> 
</mapper> 

5、测试:

@Test 
public void dbTest() throws JsonProcessingException{ 
 Person person2 = personDAO.getPersonById(2); 
 logger.info("person no 2 is: {}", objectMapper.writeValueAsString(person2)); 
 person2.setFirstName("八"); 
 personDAO.updatePersonById(person2); 
 person2 = personDAO.getPersonById(2); 
 logger.info("person no 2 after update is: {}", objectMapper.writeValueAsString(person2)); 
 assertThat(person2.getFirstName(), equalTo("八")); 
} 

总结

以上所述是小编给大家介绍的spring boot配置MySQL数据库连接、Hikari连接池和Mybatis的简单配置方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • 基于SpringMVC实现网页登录拦截

    基于SpringMVC实现网页登录拦截

    SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。因此,本文将为大家介绍如何通过SpringMVC实现网页登录拦截功能,需要的小伙伴可以了解一下
    2021-12-12
  • Java使用TarsosDSP库实现音频的处理和格式转换

    Java使用TarsosDSP库实现音频的处理和格式转换

    在音频处理领域,Java虽然有原生的音频处理类库,但其功能相对基础,而TarsosDSP是一个强大的开源音频处理库,提供了丰富的功能,本文将介绍如何在Java中结合使用TarsosDSP库,来实现音频的处理和格式转换,需要的朋友可以参考下
    2025-04-04
  • Java中的注解机制Annotation详解

    Java中的注解机制Annotation详解

    这篇文章主要介绍了Java中的注解机制Annotation详解,  Java Annotation 是 Java 语言中的一种 元数据机制,它可以在代码中添加额外的信息,以便于程序的理解和处理,Annotation 可以用来描述类、方法、属性等各种程序的特性,需要的朋友可以参考下
    2023-10-10
  • SpringBoot启动类@SpringBootApplication注解背后的秘密

    SpringBoot启动类@SpringBootApplication注解背后的秘密

    这篇文章主要介绍了SpringBoot启动类@SpringBootApplication注解背后的秘密,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • Spring Boot的无缝衔接实践案例

    Spring Boot的无缝衔接实践案例

    在快速迭代的软件开发环境中,无缝衔接是提升开发效率、降低维护成本、增强系统稳定性的关键,本文将深入解析Spring Boot无缝衔接的几大优势,并通过实际案例和深入分析,展示这些优势如何在项目中发挥作用
    2024-08-08
  • SpringBoot返回中文乱码问题解决方法汇总

    SpringBoot返回中文乱码问题解决方法汇总

    这几天在使用Spring Boot学习AOP原理的时候,通过浏览器访问后端接口的时候,响应报文总是出现中文乱码问题,下面这篇文章主要给大家介绍了关于SpringBoot返回中文乱码问题解决方法,需要的朋友可以参考下
    2023-06-06
  • SpringBoot项目改为SpringCloud项目使用nacos作为注册中心的方法

    SpringBoot项目改为SpringCloud项目使用nacos作为注册中心的方法

    本文主要介绍了SpringBoot项目改为SpringCloud项目使用nacos作为注册中心,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • SpringBoot 二维码生成base64并上传OSS的实现示例

    SpringBoot 二维码生成base64并上传OSS的实现示例

    本文主要介绍了SpringBoot 二维码生成base64并上传OSS的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • 详解Spring与MyBatis的整合的方法

    详解Spring与MyBatis的整合的方法

    这篇文章主要为大家详细介绍了Spring与MyBatis的整合,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • 使用java.nio.file 库优雅的操作文件详解

    使用java.nio.file 库优雅的操作文件详解

    这篇文章主要介绍了使用java.nio.file 库优雅的操作文件详解,需要的朋友可以参考下
    2023-05-05

最新评论