MySQL學習(六)——自定義連接池

来源:http://www.cnblogs.com/cxq1126/archive/2017/09/10/7501210.html
-Advertisement-
Play Games

1、連接池概念 用池來管理Connection,這樣可以重覆使用Connection。有了池,我們就不用自己來創建Connection,而是通過池來獲取Connection對象。當使用完Connection後,調用Connection的close()方法也不會真的關閉Connection,而是把Co ...


1、連接池概念

用池來管理Connection,這樣可以重覆使用Connection。有了池,我們就不用自己來創建Connection,而是通過池來獲取Connection對象。當使用完Connection後,調用Connection的close()方法也不會真的關閉Connection,而是把Connection“歸還”給池,池就可以再利用這個Connection對象了。

2、自定義連接池

1)基於MySQL學習(五)——使用JDBC完成用戶表CRUD的操作,把db.properties和JDBCUtils_V3.java文件複製到當前包下

2)MyConnection.java文件

裝飾者設計模式,專門用於增強方法(此處如果不對close()做增強方法,用戶調用conn.close()將連接真正釋放,連接池將無連接可用,所以我們希望用戶調用了close()方法,連接仍歸還給連接池)

 1 //1.實現同一個介面
 2 public class MyConnection implements Connection{
 3     //3.定義變數
 4     private Connection conn;
 5     
 6     private LinkedList<Connection> pool;
 7     
 8     //2.編寫一個構造方法(參數使用了面向對象的多態特性)
 9     public    MyConnection(Connection conn,LinkedList<Connection> pool){
10         this.conn=conn;
11         this.pool=pool;
12     }
13     //4.書寫需要增強的方法
14     @Override
15     public void close() throws SQLException {
16         pool.add(conn);
17     }
18     /*
19      * 此方法必須覆蓋!否則會出現空指針異常
20      */
21     @Override
22     public PreparedStatement prepareStatement(String sql) throws SQLException {
23         return conn.prepareStatement(sql);
24     }
25     ……
26 }

3)MyDataSource1.java文件

創建連接池實現數據源,並實現介面javax.sql.DataSource

 1 public class MyDataSource1 implements DataSource{
 2     //1.創建一個容器用於存儲Connection對象
 3     private static LinkedList<Connection> pool=new LinkedList<Connection>();
 4     //2.創建5個連接放到容器中去
 5     static{
 6         for(int i=0;i<5;i++){
 7             Connection conn=JDBCUtils_V3.getConnection();
 8             //放入池子中的connection對象已經經過改造了
 9             MyConnection myconn=new MyConnection(conn,pool);
10             pool.add(myconn);
11         }
12     }
13     /**
14      * 重寫獲取連接的方法
15      */
16     @Override
17     public Connection getConnection() throws SQLException {
18         Connection conn=null;
19         //3.使用前先判斷
20         if(pool.size()==0){
21             //3.1池子里沒有,我們再創建一些
22             conn=JDBCUtils_V3.getConnection();
23             pool.add(conn);
24         }
25         //4.從池子裡面獲取一個連接對象Connection
26         conn=pool.remove(0); 
27         return conn;
28     }
29     ……
30 }

4)TestMyDataSource.java文件

 1 public class TestMyDataSource {
 2     /*
 3      * 添加用戶
 4      * 使用改造過後的Connection
 5      */ 
 6     @Test
 7     public void testAddUser1(){
 8         Connection conn=null;
 9         PreparedStatement pstmt=null;
10         //1.創建自定義連接池對象
11         DataSource dataSource=new MyDataSource1();
12         
13         try {
14             //2.從池子中獲取連接
15             conn=dataSource.getConnection();
16             String sql="insert tbl_user values(null,?,?)";
17             //必須在自定義的conntection類中重寫prepareStatement(sql)語句
18             pstmt=conn.prepareStatement(sql);
19             pstmt.setString(1, "chenga");
20             pstmt.setString(2, "123");
21             int rows=pstmt.executeUpdate();
22             if(rows>0){
23                 System.out.println("添加成功");
24             }else{
25                 System.out.println("添加不成功");
26             }
27         } catch (SQLException e) {
28             e.printStackTrace();
29         }finally{
30             //調用的release()方法中的close()其實是MyConnection的close()方法,該方法內部將當前連接歸還到連接池
31             JDBCUtils_V3.release(conn,pstmt,null);         
32         }
33     }
34 }

執行Junit Test,效果如下:


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

-Advertisement-
Play Games
更多相關文章
  • 運算符 算術運算符 “+、-、*、/” 加、減、乘、除 連接運算符 “||” 連接運算符是用來連接字元串的,跟java中的"+"號是一致的。 示例: select 'abc'||'bcd' as 連接後的結果 from dual; select d.dname || '部門' from dept d ...
  • 四周昏暗,是一家小城的酒肆,屋外正是大雪紛飛。 林蔥抖了抖外套,進的店裡來,叫了兩斤熟牛肉,一壺燒酒。 “小二,最近什麼工作有前途啊?” 小二打量了一眼林蔥,只見眼前的客官濃眉大眼,身穿一件半舊西裝,一副黑框眼鏡半藏衣袋之中。遠看像個老壞蛋,近看好像朱時茂一般,越看越覺得有一個工作適合他。 “小二你 ...
  • [20170909]為什麼是12秒.txt--//在開發程式時我一般會強調開發儘量不要寫一些自定義函數,往往可能導致CPU忙。--//例子很像這樣:CREATE OR REPLACE FUNCTION get_dept (p_deptno dept.deptno%TYPE) RETURN dept. ...
  • 出現這種錯誤明顯就是 mysql_connect 之後忘記 mysql_close;當大量的connect之後,就會出現Too many connections的錯誤,mysql預設的連接為100個,而什麼情況下會出現這種錯誤呢?正常的mysql_connect 之後調用 mysql_close() ...
  • 我用的是phpstudy安裝的mysql資料庫,但是在服務中沒有mysql的啟動項(不影響使用),原因是在安裝mysql的時候沒有安裝mysql 服務 解決辦法如下: 1. 用管理員身份運行cmd.exe(註意管理員身份!) 2. 進入mysql的bin目錄 3. 安裝mysql服務 安裝服務:my ...
  • 1、查詢工資為2500到4000的人數 方式一: select count(*) from emp where sal>=2500 and sal<=4000; 方式二: select count(*) from emp where sal between 2500 and 4000; 2、查詢每個 ...
  • 本文出處:http://www.cnblogs.com/wy123/p/7501261.html (保留出處並非什麼原創作品權利,本人拙作還遠遠達不到,僅僅是為了鏈接到原文,因為後續對可能存在的一些錯誤進行修正或補充,無他) 資料庫在處理併發事物的過程中,在不同的隔離級別下有不同的鎖表現,在非可序列 ...
  • MySQL事務: 1.MySQL事務控制語句 (1).開啟事務 begin; (2).提交事務 commit; (3).回滾事務 rollback; (4).設置事務是否自動提交 set autocommit = {0 | 1}; // 0不自動提交,1自動提交 例如: begin;// 開啟事務 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...