c3p0 数据库连接池配置封装使用

1. c3p0 数据库连接池配置封装使用

引用jar包

  

工程目录结构:

c3p0 数据库连接池配置封装使用_第1张图片


package com.feng.test.c3p0;



import com.mchange.v2.c3p0.ComboPooledDataSource;


import java.sql.Connection;  
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;  
import java.util.UUID;
  
  

public class c3p0Demo2 {
	public static void main(String[] args) {
		try {
			DBUtil_BO dbBo = new DBUtil_BO();
			dbBo.conn=C3p0Utils.getConnection();//取用一个连接
			String sql = "select * from kfk_server";
			dbBo.st=dbBo.conn.prepareStatement(sql);//预处理sql语句
			//此时dbBo对象已经封装了一个数据库连接以及要执行的操作   		
			DBUtils.executeQuery(dbBo);//通过数据库操作类来执行这个操作封装类,结果封装回这个操作封装类
			//从dbBo类提取操作结果
			if (dbBo.rs.next()){
			    String str =dbBo.rs.getString("ZOOKEEPER_CONNECT");
			    System.out.println("--------------------------"+str);
			}		
			//结果集遍历完了,手动释放连接回连接池
			DBUtils.realseSource(dbBo);
		} catch (Exception e) {
			e.printStackTrace();
		}		
	}	
}


class C3p0Utils {
    static org.apache.log4j.Logger logger=org.apache.log4j.Logger.getLogger(C3p0Utils.class.getName());
    
    //通过标识名来创建相应连接池
    static ComboPooledDataSource dataSource=new ComboPooledDataSource("c3p0");
    //从连接池中取用一个连接
    public static Connection getConnection() throws Exception{
        try {
            return dataSource.getConnection();
            
        } catch (Exception e) {
            logger.error("Exception in C3p0Utils!", e);            
            throw new Exception("数据库连接出错!",e);
        }
    }    
    //释放连接回连接池
     public static void close(Connection conn,PreparedStatement pst,ResultSet rs) throws Exception{  
            if(rs!=null){  
                try {  
                    rs.close();  
                } catch (SQLException e) {  
                    logger.error("Exception in C3p0Utils!", e);
                    throw new Exception("数据库连接出错!",e);       
                }  
            }  
            if(pst!=null){  
                try {  
                    pst.close();  
                } catch (SQLException e) {  
                    logger.error("Exception in C3p0Utils!", e);
                    throw new Exception("数据库连接出错!",e);  
                }  
            }  
      
            if(conn!=null){  
                try {  
                    conn.close();  
                } catch (SQLException e) {  
                    logger.error("Exception in C3p0Utils!", e);
                    throw new Exception("数据库连接出错!",e);   
                }  
            }  
        }  
}
 
class DBUtil_BO {   
    public Connection conn = null;
    public PreparedStatement st = null;
    public ResultSet rs = null;
    public DBUtil_BO() {
        super();
    }    
}

class DBUtils {
    static org.apache.log4j.Logger logger=org.apache.log4j.Logger.getLogger(DBUtils.class.getName());
    
    
    private static void realseSource( Connection _conn, PreparedStatement _st,ResultSet _rs){    	
        try {
			C3p0Utils.close(_conn,_st,_rs);
		} catch (Exception e) {			
			logger.error("",e);
		}           
    }

       public static void realseSource(DBUtil_BO _vo){    
           if(_vo!=null){
               realseSource(_vo.conn, _vo.st, _vo.rs);
           }        
       }
       //注意:查询操作完成后,因为还需提取结果集中信息,所以仍保持连接,在结果集使用完后才通过DBUtils.realseSource()手动释放连接
       public static void executeQuery(DBUtil_BO vo)
       {        
           try{
               vo.rs = vo.st.executeQuery();
           }catch (SQLException e){            
               realseSource(vo);
               String uuid=UUID.randomUUID().toString();
               logger.error("UUID:"+uuid+", SQL语法有误: ",e);
           }    
       }
       
      //而update操作完成后就可以直接释放连接了,所以在方法末尾直接调用了realseSourse()
       public static  void executeUpdate(DBUtil_BO vo)
       {

           Connection conn = vo.conn;
           PreparedStatement st = vo.st;
           try {
               st.executeUpdate();
           } catch (SQLException e) {
               realseSource(conn, st, null);        
               String uuid=UUID.randomUUID().toString();
               logger.error("UUID:"+uuid+", SQL语法有误: ",e);               
           }
           realseSource(conn, st,null );                

       }
}





  
    con_test
    30000
    30
    10
    30
    100
    10
    200

    
      10
      1
      0
    

  

  
   
  	
    monitor3
    mnt2t3!jsdx
    oracle.jdbc.driver.OracleDriver
    jdbc:oracle:thin:@(DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1621)) (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.2)(PORT = 1621)) (LOAD_BALANCE = off) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = bondb_jf) (FAILOVER_MODE = (TYPE = SELECT) (METHOD = BASIC) (RETRIES = 30) (DELAY = 20) ) ) )
    
    
  
    50
    100
    50
    1000

    
    0 
    5

    
     
      1
      1
      1
      5
      50
    
  



运行结果:


c3p0 数据库连接池配置封装使用_第2张图片

你可能感兴趣的:(JAVA)