ホームページ >データベース >mysql チュートリアル >C3P0 接続プールの詳細な紹介

C3P0 接続プールの詳細な紹介

零下一度
零下一度オリジナル
2017-07-27 15:48:262176ブラウズ

C3P0接続プール

C3P0接続プールを作成するためのツールクラス
* 接続用の標準インターフェース:
* javax.sql.DataSourceインターフェース
* インターフェースの実装クラスオブジェクト
* ComboPooledDataSource
* メンバーにComboPooledDataSourceオブジェクトを作成location
* 静的コード ブロックを使用して、ComboPooledDataSource の 4 つの大量のデータ接続情報を設定します
* Connection オブジェクトを返す静的メソッドを作成します
* リソースを解放する静的メソッドを作成します

 1 public class C3P0Utils { 2     //成员位置创建ComboPooledDataSource对象 3     private static ComboPooledDataSource dataSource = new ComboPooledDataSource(); 4      5     //使用静态代码块给ComboPooledDataSource设置4大数据量连接信息 6     static{ 7         try { 8             dataSource.setDriverClass("com.mysql.jdbc.Driver"); 9             dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/mybase4");10             dataSource.setUser("root");11             dataSource.setPassword("root");12         } catch (Exception e) {13             throw new RuntimeException("设置连接信息失败!");14         }15     }16     17     //创建一个静态方法返回Connection对象18     public static Connection getConnection(){19         try {20             return dataSource.getConnection();21         } catch (SQLException e) {22             throw new RuntimeException("获取数据库连接信息失败!");23         }24     }25     26     //定义一个释放资源的方法27         public static void close(ResultSet rs,Statement stat,Connection conn){28             if(rs!=null){29                 try {30                     rs.close();31                 } catch (SQLException e) {32                     e.printStackTrace();33                 }34             }35             if(stat !=null){36                 try {37                     stat.close();38                 } catch (SQLException e) {39                     e.printStackTrace();40                 }41             }42             if(conn != null){43                 try {44                     conn.close();45                 } catch (SQLException e) {46                     e.printStackTrace();47                 }48             }49         }50 }

読み取り用の C3P0 ツール クラスを作成しますXML設定ファイル

 1 public class C3P0UtilsReadXML { 2     //成员位置创建ComboPooledDataSource对象 3     private static ComboPooledDataSource dataSource = new ComboPooledDataSource(); 4      5     //使用静态代码块给ComboPooledDataSource设置4大数据量连接信息 6     /*static{ 7         try { 8             dataSource.setDriverClass("com.mysql.jdbc.Driver"); 9             dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/mybase4");10             dataSource.setUser("root");11             dataSource.setPassword("root");12         } catch (Exception e) {13             throw new RuntimeException("设置连接信息失败!");14         }15     }*/16     17     //创建一个返回ComboPooledDataSource的方法18     public static DataSource getDataSource(){19         return dataSource;20     }21     22     //创建一个静态方法返回Connection对象23     public static Connection getConnection(){24         try {25             return dataSource.getConnection();26         } catch (SQLException e) {27             throw new RuntimeException("获取数据库连接信息失败!");28         }29     }30     31     //定义一个释放资源的方法32         public static void close(ResultSet rs,Statement stat,Connection conn){33             if(rs!=null){34                 try {35                     rs.close();36                 } catch (SQLException e) {37                     e.printStackTrace();38                 }39             }40             if(stat !=null){41                 try {42                     stat.close();43                 } catch (SQLException e) {44                     e.printStackTrace();45                 }46             }47             if(conn != null){48                 try {49                     conn.close();50                 } catch (SQLException e) {51                     e.printStackTrace();52                 }53             }54         }55 }

DBCP接続プール

DBCP接続プールを作成するためのツールクラス
* 接続用の標準インターフェース:
* javax.sql.DataSourceインターフェース
* インターフェースの実装クラスオブジェクト
* BasicDataSource
* getConnection メソッドをオーバーライドする

 1 public class DBCPUtils { 2     //创建连接池的实现类对象 3     private static BasicDataSource dataSource = new BasicDataSource(); 4      5     //设置连接数据库的4大变量,使用BasicDataSource中的set方法设置 6     static{ 7         //设置注册的驱动信息 8         dataSource.setDriverClassName("com.mysql.jdbc.Driver"); 9         //设置Url10         dataSource.setUrl("jdbc:mysql://localhost:3306/mybase4");11         //设置用户名12         dataSource.setUsername("root");13         //设置密码14         dataSource.setPassword("root");15         //可选信息16         //dataSource.setInitialSize(100);17         //dataSource.setMaxActive(1000);18     }19     20     //创建获取数据库连接对象的方法21     public static Connection getConnection(){22         try {23             return dataSource.getConnection();24         } catch (SQLException e) {25             throw new RuntimeException("获取数据库连接对象失败");26         }27     }28     29     //定义一个释放资源的方法30     public static void  close(ResultSet rs,Statement stat,Connection conn){31         if(rs!=null){32             try {33                 rs.close();34             } catch (SQLException e) {35                 e.printStackTrace();36             }37         }38         if(stat !=null){39             try {40                 stat.close();41             } catch (SQLException e) {42                 e.printStackTrace();43             }44         }45         if(conn != null){46             try {47                 conn.close();48             } catch (SQLException e) {49                 e.printStackTrace();50             }51         }52     }53 }

設定ファイルの読み取り方法

 1 /* 2  * 创建DBCP连接池工具类 3  * 使用读取配置文件的方式 4  * DBCP中有一个工厂类BasicDataSourceFactory 5  * 工厂类中有一个静态方法 6  * static DataSource createDataSource(Properties prop) 7  * 此方法返回的就是DataSource接口的实现类对象BasicDataSource 8  * 
 9  * 创建Propertis集合+IO技术读取配置文件10  * 把配置文件传入BasicDataSourceFactory静态方法createDataSource中11  */12 public class DBCPUtilsReadConfig {13     //创建DataSource变量14     private static DataSource dataSource;15     16     static{17         try {18             //创建Propertis集合+IO技术读取配置文件19             //使用类加载器,扫描包下的文件20             InputStream is = DBCPUtilsReadConfig.class.getClassLoader()21                     .getResourceAsStream("dbcpconfig.properties");22             //创建Propertis集合23             Properties prop = new Properties();24             prop.load(is);25             //把配置文件传入BasicDataSourceFactory静态方法createDataSource中26             dataSource = BasicDataSourceFactory.createDataSource(prop);27         } catch (Exception e) {28             throw new RuntimeException("读取配置文件失败");29         }30     }31     32     //创建获取数据库连接对象的方法33     public static Connection getConnection(){34         try {35             return dataSource.getConnection();36         } catch (SQLException e) {37             throw new RuntimeException("获取数据库连接对象失败");38         }39     }40     41     //定义一个释放资源的方法42     public static void  close(ResultSet rs,Statement stat,Connection conn){43         if(rs!=null){44             try {45                 rs.close();46             } catch (SQLException e) {47                 e.printStackTrace();48             }49         }50         if(stat !=null){51             try {52                 stat.close();53             } catch (SQLException e) {54                 e.printStackTrace();55             }56         }57         if(conn != null){58             try {59                 conn.close();60             } catch (SQLException e) {61                 e.printStackTrace();62             }63         }64     }65 }


* DBUtils ツールクラスを使用してデータベーステーブルを追加、削除、変更、確認する
* DBUtils ツールクラスの機能: JDBC 開発を簡素化する (6 ステップ)
*
* DBUtils には 3 つのコア クラスがあります
* 1.QueryRunner: QueryRunner のメソッドを使用して、データベースの追加、削除、変更、クエリを実行します
* 2.DbUtils: リソースを解放するための多数のメソッドを提供します
* 3.ResultSetHandler インターフェイス:クエリ結果セットを処理するためのメソッドを提供します
*
* QueryRunner クラス
* コンストラクター:
* QueryRunner() 空のパラメーター コンストラクター
* update メソッドと query メソッドを呼び出すときは、Connection オブジェクトを渡す必要があります
* QueryRunner (DataSource ds) DataSource データベース接続プールを持つコンストラクター
* 更新の呼び出し クエリ メソッドを呼び出すと、QueryRunner は DataSource 実装クラス オブジェクトからデータベース接続オブジェクトを自動的に取得し、使用後に自動的に返します
* メンバー メソッド:
* を実行するメンバー メソッドを実行します追加、削除、変更
* int update(Connection conn, String sql, Object ... params) 追加、削除、変更の実行に使用される SQL
* int update(String sql, Object... params) 実行に使用される SQL追加、削除、変更
* パラメータ:
* 接続 conn: データベース接続オブジェクト
* 文字列 sql: 結合された SQL ステートメントには、? プレースホルダーを使用できます
* オブジェクト... params: ? 、 Object[] を使用できます
* 戻り値:
* int: 実行される有効な行の数
* クエリ メンバー メソッドを実行
* T query(Connection conn, String sql, ResultSetHandler rsh 、オブジェクト... params)
* T query(String sql, ResultSetHandler rsh, Object ... params)
* パラメーター:
* 接続 conn: データベース接続オブジェクト
* 文字列 sql: spliced sql ステートメント、使用できますか? プレースホルダー
* Object... params:? プレースホルダーの実際のパラメーター、使用できます Object[]
* ResultSetHandler クエリ後に結果セットを保存するために使用されます。 9 種類の ResultSetHandler 実装クラスのオブジェクト
* 戻り値:
* T: 渡される ResultSetHandler 実装クラスは異なり、返される結果セットも異なります。返されます。

以上がC3P0 接続プールの詳細な紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
前の記事:MySQL の概要次の記事:MySQL の概要