ホームページ  >  記事  >  データベース  >  私の JDBC 接続は実際にプールを使用していますか?

私の JDBC 接続は実際にプールを使用していますか?

DDD
DDDオリジナル
2024-11-24 03:48:10893ブラウズ

Is My JDBC Connection Actually Using a Pool?

JDBC 接続プーリング: 実装の確認

JDBC 接続プーリングを利用しているかどうかの判断は、その単純さゆえに混乱を招く可能性があります。提供された接続クラスとその使用法を詳しく調べて、真の接続プーリングが採用されているかどうかを確認してみましょう。

接続クラス分析

提供された接続クラスは、DBCP の BasicDataSource を利用しているようです。接続管理。ただし、詳しく調べると、接続を取得するたびに新しい接続プールが確立されていることがわかります。これは、接続が単一の共有プールから取得される必要があるため、接続プーリングの基本的な概念を否定します。

さらに、接続をインスタンス変数として保持することはお勧めできません。リソースを効果的に再利用するには、必要に応じて接続を取得し、適切に閉じる必要があります。

書き直されたコードの抜粋

これらの問題を修正するために、接続クラスが改訂されました。

public final class Database {

    private static final BasicDataSource dataSource = new BasicDataSource();

    static {
        dataSource.setDriverClassName("com.mysql.jdbc.Driver");
        dataSource.setUrl("jdbc:mysql://localhost:3306/data");
        dataSource.setUsername("USERNAME");
        dataSource.setPassword("PASSWORD");
    }

    private Database() {
        //
    }

    public static Connection getConnection() throws SQLException {
        return dataSource.getConnection();
    }

}

このコードは、接続プールを一度作成し、から接続を取得する方法を提供します。

接続の使用法の改訂

接続クラスと JDBC 機能をより堅牢な方法で使用する方法は次のとおりです。

private static final String SQL_EXIST = "SELECT * FROM users WHERE username=? AND password=?";

public boolean exist(User user) throws SQLException {
    boolean exist = false;

    try (
        Connection connection = Database.getConnection();
        PreparedStatement statement = connection.prepareStatement(SQL_EXIST);
    ) {
        statement.setString(1, user.getUsername());
        statement.setString(2, user.getPassword());

        try (ResultSet resultSet = preparedStatement.executeQuery()) {
            exist = resultSet.next();
        }
    }       

    return exist;
}

これ改訂されたコードでは、try-with-resource ブロックを使用して、接続やその他のリソースが適切に解放されるようにします。

以上が私の JDBC 接続は実際にプールを使用していますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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