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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...