ホームページ >データベース >mysql チュートリアル >C3P0 接続プールの詳細な紹介
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: 実行される有効な行の数
* クエリ メンバー メソッドを実行
*
*
* パラメーター:
* 接続 conn: データベース接続オブジェクト
* 文字列 sql: spliced sql ステートメント、使用できますか? プレースホルダー
* Object... params:? プレースホルダーの実際のパラメーター、使用できます Object[]
* ResultSetHandler
* 戻り値:
*
以上がC3P0 接続プールの詳細な紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。