java學習筆記之資料庫連接池(DBCP和C3P0)

来源:https://www.cnblogs.com/xuzhaocai/archive/2018/01/04/8186506.html
-Advertisement-
Play Games

資料庫連接池(DBCP和C3P0) 一.資料庫連接池的概念 資料庫連接池可以理解為是存放多個資料庫連接的集合。 作用;解決建立資料庫連接耗費很多資源和時間問題,提高性能 Java為資料庫連接池提供了公共的介面:javax.sql.DataSource,各個廠商需要讓自己的連接池實現這個介面。這樣應用 ...


資料庫連接池(DBCP和C3P0)

一.資料庫連接池的概念

  資料庫連接池可以理解為是存放多個資料庫連接的集合。

  作用;解決建立資料庫連接耗費很多資源和時間問題,提高性能

 

  Java為資料庫連接池提供了公共的介面:javax.sql.DataSource,各個廠商需要讓自己的連接池實現這個介面。這樣應用程式可以方便的切換不同廠商的連接池!

 

  連接池圖解:
 

 二..DBCP連接池:

  1.簡單介紹:

    dbcp是apache組織的開源的連接池

  2.使用步驟:

    ①添加jar包 commons-dbcp-1.4.jar  commons-pool-1.5.6.jar

    ②,編寫配置文件(四大信息)

      配置文件名以   .properties結尾

      最好放在src目錄下

      配置文件信息如下:

driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/day05db
username=root
password=root

 

    ③編寫連接池工具類

 1 import java.sql.Connection;
 2 import java.sql.ResultSet;
 3 import java.sql.SQLException;
 4 import java.sql.Statement;
 5 import java.util.Properties;
 6 
 7 import javax.sql.DataSource;
 8 
 9 import org.apache.commons.dbcp.BasicDataSourceFactory;
10 /*
11  * javax.sql.DataSource介面
12  *    DBCP連接池實現類:
13  *      BasicDataSource
14  *      BasicDataSourceFactory
15  * 
16  * 連接池的創建步驟 :
17  *  1:創建一個空的連接池
18  *     BasicDataSource dataSource = new  BasicDataSource();
19  *  2:給這個連接池設置四大信息--->連接池會自動的向池子中存放連接 (預設一般是10個)
20  *    dataSource.setDriverClassName("com.mysql.jdbc.Driver");
21  *    dataSource.setUrl("jdbc:mysql://localhost:3306/day04db");
22  *    dataSource.setUserName("root");
23  *    dataSource.setPassword("123");
24  *    
25  *  3:封裝一個方法,對外提供一個連接池中連接 
26  *     getConntion();
27  */
28 public class MyDBCPUtils {
29     private static DataSource dataSource=null;
30     //創建一個空的連接池
31     static{
32         Properties properties=new Properties();
33         try {
34             
35             properties.load(MyDBCPUtils.class.getClassLoader().getResourceAsStream("dbcp.properties"));
36             /*MyDBCPUtils.class.getClassLoader().getResourceAsStream("dbcp.properties")
37              * 方法會自動的去bin目錄中找配置文件夾
38              */
39             /*
40              * 該方法會做兩件事情:
41              *  1:自動從Properties集合中獲取四大信息
42              *  2: 創建一個有連接的連接池
43              */
44             dataSource=BasicDataSourceFactory.createDataSource(properties);
45         } catch (Exception e) {
46             // TODO Auto-generated catch block
47             e.printStackTrace();
48         }
49         
50     }
51     /**
52      * 創建一個靜態方法 ,可以讓外界獲取連接對象
53      * @return  Connection 
54      * @throws Exception
55      */
56     public static Connection  getConnection() throws Exception{
57         return dataSource.getConnection();
58     }
59     /**
60      * 
61      * @param rs 結果集對象,沒有寫null
62      * @param stat  sql執行平臺對象
63      * @param conn  資料庫連接對象
64      */
65     public static void closeAll(ResultSet rs,Statement stat,Connection conn){
66         
67         if(rs!=null){
68             try {
69                 rs.close();
70             } catch (SQLException e) {
71                 // TODO Auto-generated catch block
72                 e.printStackTrace();
73             }
74         }
75         if(stat!=null){
76             try {
77                 stat.close();
78             } catch (SQLException e) {
79                 // TODO Auto-generated catch block
80                 e.printStackTrace();
81             }
82         }
83         
84         //這裡這個close不是關流釋放資源,而是重寫方法,將連接放回連接池
85         if(conn!=null){
86             try {
87                 conn.close();
88             } catch (SQLException e) {
89                 // TODO Auto-generated catch block
90                 e.printStackTrace();
91             }
92         }
93     }
94 
95 }

  ④使用編寫的工具類(簡單demo)

 1 import java.sql.Connection;
 2 import java.sql.PreparedStatement;
 3 import java.sql.ResultSet;
 4 
 5 public class Test01 {
 6     public static void main(String[] args)throws  Exception{
 7         //獲得連接
 8         Connection conn = MyDBCPUtils.getConnection();
 9         
10         //獲得sql語句的執行平臺
11         PreparedStatement stat = conn.prepareStatement("select * from student");
12         //獲得結果集
13         ResultSet result = stat.executeQuery();
14         //處理結果集
15         
16         while(result.next()){
17             System.out.println(result.getInt("stu_id"));
18         }
19         //釋放資源
20         MyDBCPUtils.closeAll(result, stat, conn);
21         
22     }
23 
24 }

 

 

三.C3P0連接池

  1.簡單介紹

    C3P0開源免費的連接池!目前使用它的開源項目有:SpringHibernate等。使用第三方工具需要導入jar包,c3p0使用時還需要添加配置文件 c3p0-config.xml

  2使用步驟:

    ①:導入jar包

    ②:編寫配置文件

        文件類型:xml

        文件名必須是 c3p0-config.xml,放在src中

        簡單的文件demo:

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 
 3 <!--
 4             dataSource.setDriverClass("com.mysql.jdbc.Driver");
 5             dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/day05db");
 6             dataSource.setUser("root");
 7             dataSource.setPassword("123");
 8 
 9       1:獲取name屬性:driverClass
10       2:進行字元串拼接:setDriverClass
11       3: 反射setDriverClass()
12       4: 調用setDriverClass()給變數賦值:com.mysql.jdbc.Driver
13  -->
14 <c3p0-config> 
15     <default-config>
16          <property name="driverClass">com.mysql.jdbc.Driver</property>
17          <property name="jdbcUrl">jdbc:mysql://localhost:3306/day05db</property>
18          <property name="user">root</property>
19          <property name="password">123</property>
20     </default-config>
21 </c3p0-config>

 

 

  ③編寫連接池使用工具類

  

 1 /*
 2  * javax.sql.DataSource介面
 3  *    實現類:ComboPooledDataSource
 4  *    
 5  * 創建連接池:
 6  *   1:創建一個空的連接池
 7  *      ComboPooledDataSource dataSource = new ComboPooledDataSource();
 8  *   2: 設置四大信息--->連接池會自動的存放連接
 9  *     dataSource.setXxx("");
10  *     dataSource.setXxx("");
11  *     dataSource.setXxx("");
12  *     dataSource.setXxx("");
13  */
14 
15 public class MyC3P0Utils {
16     /*
17      * 1:該對象在創建的時候會自動的檢測是否有c3p0-config.xml
18      * 2: 如果沒有c3p0-config.xml
19      *    你需要手動的設置四大信息
20      * 3: 如果有c3p0-config.xml
21      *    1:該對象在創建的時候會自動的解析xml文件
22      *    2:獲取四大信息
23      *    3: 創建連接池,並向連接池中存放連接池
24      */
25     private static DataSource dataSource = new ComboPooledDataSource();
26 
27     //封裝一個方法,讓別人能夠獲取連接池中的連接
28     public static Connection getConnetion()throws Exception{
29         
30         return dataSource.getConnection();
31     }
32     
33     public static void closeAll(ResultSet rs, Statement stat, Connection conn) {
34         if (rs != null) {
35             try {
36                 rs.close();
37             } catch (SQLException e) {
38                 e.printStackTrace();
39             }
40         }
41         if (stat != null) {
42             try {
43                 stat.close();
44             } catch (SQLException e) {
45                 e.printStackTrace();
46             }
47         }
48         if (conn != null) {
49             try {
50                 conn.close();// 連接池已經重寫類該方法,該方法是將連接重新放回到連接池
51             } catch (SQLException e) {
52                 e.printStackTrace();
53             }
54         }
55     }
56 }

 

  ④使用工具類

 1 import java.sql.Connection;
 2 import java.sql.PreparedStatement;
 3 
 4 public class TestDemo01 {
 5     public static void main(String[] args) throws Exception {
 6         //1:獲取連接
 7          Connection conn = MyC3P0Utils.getConnetion();
 8         //2:執行sql
 9         PreparedStatement stat = conn.prepareStatement("delete from category where cid = ?");
10         stat.setObject(1, 2);
11         int rows = stat.executeUpdate();
12         
13         //3:處理結果
14         if(rows > 0){
15             System.out.println("刪除成功");
16         }else{
17             System.out.println("刪除失敗");
18         }
19         
20         //4: 釋放資源
21         MyC3P0Utils.closeAll(null, stat, conn);
22     }
23 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、vertical-align基本認識 支持的屬性值: ①線類:baseline(預設),top,middle,bottom ②文本類:text-top,text-bottom ③上標下標類:sub,super ④數值百分比類: 數值和百分比的共性:ⅰ都帶數字;ⅱ都支持負值;ⅲ行為表現一致(都是在 ...
  • 一、表單輸入綁定 1.1、基礎用法 你可以用 v-model 指令在表單控制項元素上創建雙向數據綁定。它會根據控制項類型自動選取正確的方法來更新元素。儘管有些神奇,但 v-model 本質上不過是語法糖,它負責監聽用戶的輸入事件以更新數據,並特別處理一些極端的例子。 v-model 並不關心表單控制項初始 ...
  • 上文說到,有了Spring之後,通過依賴註入的方式,我們的業務代碼不用自己管理關聯對象的生命周期。業務代碼只需要按照業務本身的流程,走啊走啊,走到哪裡,需要另外的對象來協助了,就給Spring說,我想要個對象——於是Spring就很貼心的給你個對象。聽起來似乎很簡單,使用起來也不難,但是如果僅僅是這 ...
  • 寫在開始 小程式升級實時音視頻錄製及播放能力,開放 Wi Fi、NFC(HCE) 等硬體連接功能。同時提供按需載入、自定義組件和更多訪問層級等新特性,增強了第三方平臺的能力,以滿足日趨豐富的業務需求。 為更高效地連接用戶與商家,小程式提供了實時音視頻錄製及播放組件。符合類目要求的小程式自助開通後,可 ...
  • 概要 瞭解數據 分析數據問題 清洗數據 整合代碼 瞭解數據 在處理任何數據之前,我們的第一任務是理解數據以及數據是乾什麼用的。我們嘗試去理解數據的列/行、記錄、數據格式、語義錯誤、缺失的條目以及錯誤的格式,這樣我們就可以大概瞭解數據分析之前要做哪些“清理”工作。 本次我們需要一個 patient_h ...
  • ngrok介紹 是一個反向代理軟體,最早是因為微信調試需要而使用。後來發現用途不少,我常用的主要是以下方面: 微信調試; 需要,比如第三方登陸或者支付的 ; 對隧道中的 請求抓包分析; 將區域網的 埠映射出來(比如你的朋友請你遠程技術支持 ,通過此方式可以直接 到對方電腦,不要用慢吞吞的遠程桌面了 ...
  • 項目中參數校驗,用到JSR 303,在此總結梳理下知識脈絡,拋磚引玉。 一、基礎 1.What is JSR? JSR是Java Specification Requests的縮寫,意思是Java 規範提案。任何人都可以提交JSR,以向Java平臺增添新的API和服務。JSR已成為Java界的一個重 ...
  • 1. Python的函數 1.1 函數的定義 在Python中,函數是邏輯結構化和過程化的一種方法;是帶名字的、組織好的、可重覆使用的代碼塊,用於完成具體的任務。Python用def關鍵字來定義函數,然後用return關鍵字返回值,其語法格式如下: def 函數名稱([參數1],[參數2],..., ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...