Mybatis使用c3p0

Mybatis支持第三方连接池
在Mybatis官方有提到第三方连接池的实现:

你可以通过实现接口 org.apache.ibatis.datasource.DataSourceFactory 来使用第三方数据源实现:

public interface DataSourceFactory { void setProperties(Properties
props); DataSource getDataSource(); }
org.apache.ibatis.datasource.unpooled.UnpooledDataSourceFactory
可被用作父类来构建新的数据源适配器,比如下面这段插入 C3P0 数据源所必需的代码:

import
org.apache.ibatis.datasource.unpooled.UnpooledDataSourceFactory;
import com.mchange.v2.c3p0.ComboPooledDataSource;

public class C3P0DataSourceFactory extends UnpooledDataSourceFactory {

public C3P0DataSourceFactory() {
this.dataSource = new ComboPooledDataSource(); } }

也可以查看官网: Mybatis官网
可以看输出需要实现

org.apache.ibatis.datasource.DataSourceFactory

这个接口 或者继承 这个类

org.apache.ibatis.datasource.unpooled.UnpooledDataSourceFactory

查看源码可以看出UnpooledDataSourceFactory已经实现了DataSourceFactory接口,我们只需要继承UnpooledDataSourceFactory并在构造器中添加c3p0的连接对象即可

  • 1 使用maven导包
        <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.23</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.mchange/c3p0 -->
        <dependency>
            <groupId>com.mchange</groupId>
            <artifactId>c3p0</artifactId>
            <version>0.9.5.2</version>
        </dependency>
<!--        Mybaatis-->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.5</version>
        </dependency>
  • 2 写入Mybatis-config.xml配置信息
    这里注意c3p0和mybatis使用的数据源名称不一致 Mybatis配置信息时需要使用c3p0的数据源名称
<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在SSM框架中使用MyBatis,需要进行以下步骤: 1. 引入MyBatis的依赖。在Maven项目中,在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.6</version> </dependency> ``` 2. 配置数据源。在Spring的配置文件中,配置数据源,建议使用连接池,可以提高数据库连接的效率。 ```xml <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> <property name="driverClass" value="${jdbc.driverClass}" /> <property name="jdbcUrl" value="${jdbc.jdbcUrl}" /> <property name="user" value="${jdbc.user}" /> <property name="password" value="${jdbc.password}" /> <property name="maxPoolSize" value="${jdbc.maxPoolSize}" /> <property name="minPoolSize" value="${jdbc.minPoolSize}" /> <property name="initialPoolSize" value="${jdbc.initialPoolSize}" /> <property name="maxIdleTime" value="${jdbc.maxIdleTime}" /> </bean> ``` 3. 配置MyBatisSqlSessionFactory。SqlSessionFactory是MyBatis的核心类,用于创建SqlSession对象。 ```xml <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="typeAliasesPackage" value="com.example.model" /> <property name="mapperLocations" value="classpath*:mappers/*.xml" /> </bean> ``` 4. 配置MyBatis的MapperScannerConfigurer。MapperScannerConfigurer是MyBatis提供的扫描Mapper接口的类,用于自动创建Mapper接口的实现类。 ```xml <bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.example.dao" /> </bean> ``` 5. 创建Mapper接口。在com.example.dao包下创建Mapper接口,使用注解或者XML文件定义SQL语句。 ```java public interface UserMapper { @Select("select * from user where id=#{id}") User selectById(int id); } ``` 6. 使用Mapper接口。在Service层中注入Mapper接口,调用Mapper方法。 ```java @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; public User selectById(int id) { return userMapper.selectById(id); } } ``` 以上就是SSM框架中使用MyBatis的基本流程。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值