mysql c3p0 mybatis_spring boot整合mybatis深坑之c3p0的详细配置

本文介绍如何在Spring Boot项目中整合C3P0数据源并详细配置其参数。通过创建数据源配置类,实现对数据源的精确控制,并确保事务处理正确无误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目地址:https://gitee.com/zhangjunqing/spring-boot/tree/master/springboot-mybatis-notice

本人在c3p0数据源整合过程中,需要详细配置各种参数,但是根据网上的各种资料配置后发现都测试不对

1 场景重现网上很多数据源的配置都是以下类似方式进行配置的:

lazy.gif

2  跟踪debug查看spring 中的数据源 acquireIncrement的值依然是默认值3

lazy.gif

3 只能手动配置数据源

思路:增加数据源配置类,将spring启动数据源信息注入到配置类中,生成datasource,配置类如下:

packagecom.springboot.config;importjavax.annotation.Resource;importjavax.sql.DataSource;importorg.springframework.beans.factory.annotation.Qualifier;importorg.springframework.boot.autoconfigure.jdbc.DataSourceBuilder;importorg.springframework.boot.context.properties.ConfigurationProperties;importorg.springframework.context.annotation.Bean;importorg.springframework.context.annotation.Primary;public classDatasourceConfiguration {

@Bean(name= "dataSource")

@Qualifier(value= "dataSource")

@Primary

@ConfigurationProperties(prefix= "spring.datasource")publicDataSource dataSource(){return DataSourceBuilder.create().type(com.mchange.v2.c3p0.ComboPooledDataSource.class).build();

}

}

4  启动参数如下:

spring:

datasource:

jdbcUrl: jdbc:mysql://localhost:3306/test

user: root

password:

driverClass: com.mysql.jdbc.Driver

type: com.mchange.v2.c3p0.ComboPooledDataSource

acquireIncrement: 11

acquireRetryAttempts: 7

特别注意:此处的配置已经和上面的URL,username等都不一样了,此处配置的详情应该参考c3p0中ComboPooledDataSource的参数,类似如下截图:

lazy.gif

5 进行测试,数据注入正确,并且经过测试事物也正常

lazy.gif

6  查看类DataSourceBuilder,发现好像spring的连接池就默认集成配置这几个,如果使用别的数据源例如阿里的上面的方法应该也适用

lazy.gif

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值