看程序学mybatis 相关概念8 - 单纯的MYBATIS整合C3P0数据库连接池

步骤 1 : 下载JAR包
下载c3p0的jar包
步骤 2 : 导入项目
把jar包导入到项目中,导包办法:右键 project->properties->java build path->libaries->add external jars
在这里插入图片描述
步骤 3 : 新建类C3P0DataSourceFactory
Mybatis使用C3P0有点怪怪的,需要自己写个类继承UnpooledDataSourceFactory,然后指定dataSource 为ComboPooledDataSource。
这个ComboPooledDataSource就是c3p0的数据源。

package org.mybatis.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();
     
        }
     
    }

步骤 4 : 配置 mybatis-config.xml
注释掉type="POOLED"的数据源,换成type="org.mybatis.c3p0.C3P0DataSourceFactory"的数据源
这样就使用c3p0了。
因为代码插件的bug,有一些关键字符不能正常显示,请直接使用右上角的mybatis-config.xml,保证顺利运行。
步骤 5 : 测试
随便运行前面知识点的任意测试类即可。
作为数据库连接池,无法在小规模访问里看到其效果,需要高并发才能体现出其效果,这里的测试代码只能表示正常运行,无法体现其优越性。

package com.how2java;
 
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
 
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
 
import com.how2java.pojo.Category;
 
public class TestMybatis {
 
    public static void main(String[] args) throws IOException {
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        SqlSession session = sqlSessionFactory.openSession();
        List<Category> cs =session.selectList("listCategory");
        for (Category c : cs) {
            System.out.println(c.getName());
        }
 
        session.close();
         
}
 
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值