连接池connection.close并非关闭数据库链接

我现在有个C3P0连接池的代码。。。是以前前辈留下的。。。现在我不会使用,今天放出来就CSDN的大哥帮忙看看如何在BEAN   和JSP里调用!??

package   C3P0;
import   java.sql.Connection;
import   java.sql.SQLException;
import   java.beans.PropertyVetoException;
import   com.mchange.v2.c3p0.ComboPooledDataSource;
public   class   DBPool{      
    private   static   DBPool   dbPool;      
    private   ComboPooledDataSource   dataSource;    

    static   {      
            dbPool=new   DBPool();      
    }      
   
    public   DBPool(){      
            try   {      
                    dataSource=new   ComboPooledDataSource();      
                    dataSource.setUser( "id ");      
                    dataSource.setPassword( "pw ");      
                    dataSource.setJdbcUrl( "jdbc:mysql://127.0.0.1:3306/test?

autoReconnect=true&useUnicode=true&characterEncoding=GB2312 ");
                    dataSource.setDriverClass( "com.mysql.jdbc.Driver ");
                    dataSource.setInitialPoolSize(2);
                    dataSource.setMinPoolSize(1);
                    dataSource.setMaxPoolSize(10);
                    dataSource.setMaxStatements(50);
                    dataSource.setMaxIdleTime(60);      
            }   catch   (PropertyVetoException   e)   {      
                throw   new   RuntimeException(e);      
            }      
    }      

    public   final   static   DBPool   getInstance(){      
            return   dbPool;      
    }      

    public   final   Connection   getConnection()   {      
            try   {      
                    return   dataSource.getConnection();      
            }   catch   (SQLException   e)   {      
                    throw   new   RuntimeException( "无法从数据源获取连接 ",e);      
            }      
    }    
   
    public   static   void   main(String[]   args)   throws   SQLException   {
Connection   con   =   null;
try   {
con   =   DBPool.getInstance().getConnection();
}   catch   (Exception   e){
}   finally   {
if   (con   !=   null)
con.close();
}
}
}

 

引用 8 楼 xyflash 的回复:
每用一次都要
  Connection  conn  =  DBPool.getInstance.getConnection();
一次。。感觉没起到连接池的作用啊



楼主,使用连接池的时候并不是在代码中不用获取/释放数据库连接,而是在代码中向连接池申请/释放连接,对于代码而言,可以把连接池看成数据库。

换句话说,连接池就是数据库的代理,之所以要使用这个代理是因为直接向数据库申请/释放连接是要降低性能的:如果每一次数据访问请求都必须经历建立数据库 连接、打开数据库、存取数据和关闭数据库连接等步骤,而连接并打开数据库是一件既消耗资源又费时的工作,那么频繁发生这种数据库操作时,系统的性能必然会 急剧下降。

连接池的作用是自己维护数据库连接,数据库连接池的主要操作如下:
  (1)建立数据库连接池对象(服务器启动)。
  (2)按照事先指定的参数创建初始数量的数据库连接(即:空闲连接数)。
  (3)对于一个数据库访问请求,直接从连接池中得到一个连接。如果数据库连接池对象中没有空闲的连接,且连接数没有达到最大(即:最大活跃连接数),创建一个新的数据库连接。
  (4)存取数据库。
  (5)关闭数据库,释放所有数据库连接(此时的关闭数据库连接,并非真正关闭,而是将其放入空闲队列中。如实际空闲连接数大于初始空闲连接数则释放连接)。
  (6)释放数据库连接池对象(服务器停止、维护期间,释放数据库连接池对象,并释放所有连接)。

 

从连接池获取的连接connection跟JDK中的connection有点不同,前者的close方法并没有关闭与数据库的连接,而是将连接返回到池中,这样就可以复用了。如果不调用close方法的话拿就失去了使用连接池的意义了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个异常通常表示在调用 `con.close()` 时,`con` 对象为 `null`。这种情况通常有以下几种可能性: 1. 在获取连接时出现异常,导致 `conn` 为 `null`。在使用连接时,应该先判断连接是否为 `null`,避免出现空指针异常。 2. 在使用连接后,没有及时关闭连接,导致连接被其他线程关闭,此时再次关闭连接时,会出现空指针异常。在使用连接后,应该及时关闭,避免出现这种情况。 3. 程序中出现并发问题,导致多个线程同时使用同一个连接,其中一个线程关闭连接,另一个线程再次关闭连接时,会出现空指针异常。应该在程序中避免这种并发问题。 针对以上情况,可以采取以下措施: 1. 在获取连接时,应该先判断连接是否为 `null`,避免出现空指针异常。 ```java // 获取数据库连接 Connection conn = ds.getConnection(); if (conn != null) { try { // 执行数据库操作 // ... } finally { // 将连接放回连接 conn.close(); } } ``` 2. 在使用连接后,应该及时关闭连接,释放资源,避免出现连接被其他线程关闭的情况。 ```java // 获取数据库连接 Connection conn = ds.getConnection(); try { // 执行数据库操作 // ... } finally { if (conn != null) { try { conn.close(); } catch (SQLException e) { // 异常处理 } } } ``` 3. 在程序中避免并发问题,可以采用线程安全的方式访问数据库连接。可以使用连接提供的线程来管理连接,每个线程从线程中获取连接,使用完毕后将连接放回线程中。这样可以避免并发问题,提高程序的性能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值