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
  • 前言 本文介紹一款使用 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 ...