c3p0连接池模板
连接池是创建和管理一个连接的缓冲池的技术,这些连接准备好被任何需要它们的线程使用。 我现在做一个p3c0连接池的模板。 首先p3c0是开源的,所以去官网下载p3c0的jar包。在工程中导入,同时要下载你连接数据库的驱动 连接池模板代码如下: package com.fish
连接池是创建和管理一个连接的缓冲池的技术,这些连接准备好被任何需要它们的线程使用。
我现在做一个p3c0连接池的模板。
首先p3c0是开源的,所以去官网下载p3c0的jar包。在工程中导入,同时要下载你连接数据库的驱动
连接池模板代码如下:
package com.fish; import java.beans.PropertyVetoException; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.ResourceBundle; import com.mchange.v2.c3p0.ComboPooledDataSource; /** * 连接数据库的工具类,被定义成不可继承且是私有访问 */ public final class DBTool { //采用配置文件的方式配置连接池的一些信心,这个是配置文件的名字 final private static String OPTION_FILE_NAME = "mysqldatabase"; private static Connection conn; static ResourceBundle res; //连接池的类 static ComboPooledDataSource cpds; static { //从配置文件中获取文件 res = ResourceBundle.getBundle(OPTION_FILE_NAME); //创建一个连接池 cpds = new ComboPooledDataSource(); //驱动名 String driver = res.getString("jdbc.driver"); //连接url String url = res.getString("jdbc.url"); //数据库用户名 String user = res.getString("jdbc.username"); //数据库密码 String password = res.getString("jdbc.password"); //连接池的最大连接数 String poolMax = res.getString("c3p0.maxPoolSize"); //连接池的最小连接数 String poolMin = res.getString("c3p0.minPoolSize"); //当资源用尽时,允许连接的数目 String PoolAcquireIncrement = res.getString("c3p0.acquireIncrement"); try { cpds.setDriverClass(driver); } catch (PropertyVetoException e) { System.out.println("驱动没找到"); } cpds.setJdbcUrl(url); cpds.setUser(user); cpds.setPassword(password); cpds.setMinPoolSize(Integer.parseInt(poolMin)); cpds.setAcquireIncrement(Integer.parseInt(PoolAcquireIncrement)); cpds.setMaxPoolSize(Integer.parseInt(poolMax)); } /** * 获取数据库的连接 * * @return conn */ public static Connection getConnection() { try { conn = cpds.getConnection(); } catch (SQLException e) { System.out.println("连接失败"); } return conn; } /** * 释放资源 * */ public static void closeJDBC(Connection conn, Statement statement, ResultSet rs) { if (null != rs) { try { rs.close(); } catch (SQLException e) { e.printStackTrace(); throw new RuntimeException(e); } finally { if (null != statement) { try { statement.close(); } catch (SQLException e) { e.printStackTrace(); throw new RuntimeException(e); } finally { if (null != conn) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); throw new RuntimeException(e); } } } } } } } }
2.mysqldatabase.properties文件如下:
jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://127.0.0.1:3306/datacenter3 jdbc.username=root jdbc.password=1234 c3p0.maxPoolSize = 30 c3p0.minPoolSize = 10 c3p0.acquireIncrement =10 以后你要连接什么数据库直接在这个文件里面修改。 测试:例子 package com.fish; public class Test2 { public static void main(String[] args) throws Exception { System.out.println(DBTool.getConnection()); } } 输出结果: 2014-11-16 14:44:04 com.mchange.v2.log.MLog <clinit> 信息: MLog clients using java 1.4+ standard logging. 2014-11-16 14:44:04 com.mchange.v2.c3p0.C3P0Registry banner 信息: Initializing c3p0-0.9.2.1 [built 20-March-2013 11:16:28 +0000; debug? true; trace: 10] 2014-11-16 14:44:04 com.mchange.v2.c3p0.impl.AbstractPoolBackedDataSource getPoolManager 信息: Initializing c3p0 pool... com.mchange.v2.c3p0.ComboPooledDataSource [ acquireIncrement -> 10, acquireRetryAttempts -> 30, acquireRetryDelay -> 1000, autoCommitOnClose -> false, automaticTestTable -> null, breakAfterAcquireFailure -> false, checkoutTimeout -> 0, connectionCustomizerClassName -> null, connectionTesterClassName -> com.mchange.v2.c3p0.impl.DefaultConnectionTester, dataSourceName -> 1hge1d1951evdfumup12ui|5ffb18, debugUnreturnedConnectionStackTraces -> false, description -> null, driverClass -> com.mysql.jdbc.Driver, factoryClassLocation -> null, forceIgnoreUnresolvedTransactions -> false, identityToken -> 1hge1d1951evdfumup12ui|5ffb18, idleConnectionTestPeriod -> 0, initialPoolSize -> 3, jdbcUrl -> jdbc:mysql://127.0.0.1:3306/datacenter3, maxAdministrativeTaskTime -> 0, maxConnectionAge -> 0, maxIdleTime -> 0, maxIdleTimeExcessConnections -> 0, maxPoolSize -> 30, maxStatements -> 0, maxStatementsPerConnection -> 0, minPoolSize -> 10, numHelperThreads -> 3, preferredTestQuery -> null, properties -> {user=******, password=******}, propertyCycle -> 0, statementCacheNumDeferredCloseThreads -> 0, testConnectionOnCheckin -> false, testConnectionOnCheckout -> false, unreturnedConnectionTimeout -> 0, userOverrides -> {}, usesTraditionalReflectiveProxies -> false ] com.mchange.v2.c3p0.impl.NewProxyConnection@d19bc8

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









この記事では、PHP が行を CSV にフォーマットし、ファイル ポインタを書き込む方法について詳しく説明します。非常に実践的だと思いますので、参考として共有します。この記事を読んで何かを得ることができれば幸いです。行を CSV にフォーマットし、ファイル ポインターに書き込む ステップ 1: ファイル ポインターを開く $file=fopen("path/to/file.csv","w"); ステップ 2: fputcsv( ) 関数を使用して行を CSV 文字列に変換するCSV文字列に変換します。この関数は次のパラメータを受け入れます。 $file: ファイル ポインタ $fields: 配列としての CSV フィールド $delimiter: フィールド区切り文字 (オプション) $enclosure: フィールド引用符 (

Keep 体脂肪計の接続方法 Keep には特別に設計された体脂肪計がありますが、ほとんどのユーザーは Keep 体脂肪計の接続方法を知りません。エディターがユーザーにもたらすもの、興味のあるユーザーは見に来てください! Keep 体脂肪計の接続方法 1. まず Keep ソフトウェアを開き、メイン ページに移動し、右下隅の [マイ] をクリックして、[スマート ハードウェア] を選択します; 2. 次に、[マイ スマート デバイス] ページで、中央の[デバイスの追加]ボタンをクリックします; 3、インターフェイスを追加するデバイスを選択し、[スマート体脂肪/体重計]を選択します; 4.デバイスモデルの選択ページで、[体脂肪スケールを維持する]をクリックしますオプション; 5. 最後に、以下のインターフェイスで、最後に下部の[今すぐ追加]

StableDiffusion3 の論文がついに登場しました!このモデルは2週間前にリリースされ、Soraと同じDiT(DiffusionTransformer)アーキテクチャを採用しており、リリースされると大きな話題を呼びました。前バージョンと比較して、StableDiffusion3で生成される画像の品質が大幅に向上し、マルチテーマプロンプトに対応したほか、テキスト書き込み効果も向上し、文字化けが発生しなくなりました。 StabilityAI は、StableDiffusion3 はパラメータ サイズが 800M から 8B までの一連のモデルであると指摘しました。このパラメーター範囲は、モデルを多くのポータブル デバイス上で直接実行できることを意味し、AI の使用を大幅に削減します。

この論文では、自動運転においてさまざまな視野角 (遠近法や鳥瞰図など) から物体を正確に検出するという問題、特に、特徴を遠近法 (PV) 空間から鳥瞰図 (BEV) 空間に効果的に変換する方法について検討します。 Visual Transformation (VT) モジュールを介して実装されます。既存の手法は、2D から 3D への変換と 3D から 2D への変換という 2 つの戦略に大別されます。 2D から 3D への手法は、深さの確率を予測することで高密度の 2D フィーチャを改善しますが、特に遠方の領域では、深さ予測に固有の不確実性により不正確さが生じる可能性があります。 3D から 2D への方法では通常、3D クエリを使用して 2D フィーチャをサンプリングし、Transformer を通じて 3D と 2D フィーチャ間の対応のアテンション ウェイトを学習します。これにより、計算時間と展開時間が増加します。

1. イヤホンをイヤホンボックスに入れて蓋を開けたままにし、ボックスのボタンを長押ししてイヤホンのペアリング状態にします。 2. 時計の音楽機能をオンにして Bluetooth ヘッドフォンを選択するか、時計の設定機能で Bluetooth ヘッドフォンを選択します。 3. 正常にペアリングするウォッチのヘッドセットを選択します。

Edge ブラウザを使用して Web ページにアクセスすると、接続が専用接続ではないというプロンプトが表示され、Web ブラウジングが失敗したことがありますか?これはどうなっているでしょうか?多くの友人はこの問題への対処方法を知りません。次の 3 つの解決策を参照してください。方法 1 (単純かつ粗雑): エッジ ブラウザでは、設定を入力してセキュリティ機能をオフにし、Web サイトのアクセス許可で位置情報の許可をブロックすることで、Web サイトにアクセスできない問題を解決できます。このアプローチの有効性と期間はさまざまであり、具体的な効果を判断することはできないことに注意することが重要です。ブラウザを再起動した後、Web サイトにアクセスして問題が解決したかどうかを確認してください。方法 2: キーボードを英語入力に調整する

BluetoothコントローラーをGohan Arcadeに接続するにはどうすればよいですか? Gohan Game Center は多くのモバイル ゲーム プレーヤーに使用されているゲーム ボックスです。人気のゲーム リソースと豊富なゲーム関連機能が多数含まれています。以下では編集者がゲーム コントローラーの接続方法を紹介します。プレイヤーの皆様はぜひご覧ください。 1. まず、Gohan Game Center APP のホームページにアクセスし、ホームページの右下隅にある「マイ」オプションをクリックします; 2. マイページで [コントローラー] 機能を見つけます。場所は図に示されています。下記を選択し、クリックして設定に移動します; 3. 選択してオンにします 携帯電話の Bluetooth 機能については、コントローラーの電源がオンになっていることを確認します; 4. 最後に、コントローラーの指示に従って、一致する接続を確立します. 接続に成功すると、モバイルゲームを使用してさまざまなゲームを体験できます。

Keep を Huawei ブレスレットに接続する方法? Keep ソフトウェアで Huawei ブレスレットを接続できます. ほとんどのユーザーは Huawei ブレスレットの接続方法を知りません. 次に、編集者が提供した Keep と Huawei ブレスレットの接続方法のグラフィックチュートリアルです. 興味のあるユーザーは来てくださいそして見てください! Keep を Huawei ブレスレットに接続する方法 1. まず Keep アプリケーションを開き、メインページの右下隅にある [Me] をクリックして特別なエリアに入り、[Smart Hardware] を選択します; 2. 次に、My Smart Device に挑戦します機能ページで、中央の[デバイスの追加]をクリックします; 3. 次に、追加するデバイスを選択するページで、[スマートブレスレット/ウォッチ]機能を選択します; 4. 最後に、以下に示すインターフェースで、接続するHuaweiウォッチのモデル。
