Java里怎么写一个数据库连接池

在Java中创建数据库连接池通常不建议从零开始,因为这涉及线程安全、资源管理和性能优化等复杂问题。业界有成熟且经过广泛测试的库,如HikariCP、C3P0和DBCP等。这里以HikariCP为例,展示如何在Java中配置和使用数据库连接池。

### 步骤 1: 添加依赖

在你的项目中添加HikariCP的依赖。如果你使用的是Maven,可以在`pom.xml`中添加如下依赖:

```xml
<dependency>
    <groupId>com.zaxxer</groupId>
    <artifactId>HikariCP</artifactId>
    <version>5.0.1</version>
</dependency>
```

### 步骤 2: 配置HikariCP

在你的Java代码中配置HikariCP。以下是一个配置示例:

```java
import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;

public class DatabaseConnectionPool {
    private static HikariDataSource dataSource;

    static {
        HikariConfig config = new HikariConfig();
        config.setJdbcUrl("jdbc:mysql://localhost:3306/your_database");
        config.setUsername("your_username");
        config.setPassword("your_password");
        config.addDataSourceProperty("cachePrepStmts", "true");
        config.addDataSourceProperty("prepStmtCacheSize", "250");
        config.addDataSourceProperty("prepStmtCacheSqlLimit", "2048");

        // 设置连接池的最小和最大连接数
        config.setMinimumIdle(5);
        config.setMaximumPoolSize(10);

        dataSource = new HikariDataSource(config);
    }

    public static HikariDataSource getDataSource() {
        return dataSource;
    }
}
```

### 步骤 3: 使用连接池

在你的业务代码中,可以使用以下方式从连接池中获取和释放连接:

```java
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

public class Service {
    public void doSomething() {
        HikariDataSource ds = DatabaseConnectionPool.getDataSource();
        try (Connection connection = ds.getConnection();
             PreparedStatement statement = connection.prepareStatement("SELECT * FROM your_table")) {
            ResultSet resultSet = statement.executeQuery();
            while (resultSet.next()) {
                // 处理数据
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
```

使用`try-with-resources`语句可以确保连接在使用完毕后被正确释放。

### 总结

通过上述步骤,你可以使用HikariCP在Java中轻松地创建和管理数据库连接池。HikariCP是一个高性能的连接池实现,它在性能和资源管理方面都优于传统的DBCP和C3P0。

  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,我可以为您提供一个简单的Java数据库连接池实现,此实现仅用于学习和演示目的。请注意,这不是一个完整的、生产就绪的连接池实现,因为它缺少许多功能,例如:连接泄漏检测、空闲连接检测、最大连接数限制等。 首先,我们需要创建一个数据库连接池类。以下是一个简单的实现: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; public class ConnectionPool { private String jdbcUrl; private String username; private String password; private List<Connection> connectionPool; private List<Connection> usedConnections = new ArrayList<>(); private final int INITIAL_POOL_SIZE = 10; public ConnectionPool(String jdbcUrl, String username, String password) { this.jdbcUrl = jdbcUrl; this.username = username; this.password = password; connectionPool = new ArrayList<>(INITIAL_POOL_SIZE); for (int i = 0; i < INITIAL_POOL_SIZE; i++) { try { Connection connection = DriverManager.getConnection(jdbcUrl, username, password); connectionPool.add(connection); } catch (SQLException e) { System.err.println(e.getMessage()); } } } public synchronized Connection getConnection() { Connection connection = null; if (connectionPool.size() > 0) { connection = connectionPool.remove(connectionPool.size() - 1); usedConnections.add(connection); } else { System.err.println("No more connections available."); } return connection; } public boolean releaseConnection(Connection connection) { boolean released = usedConnections.remove(connection); if (released) { connectionPool.add(connection); } return released; } public int getSize() { return connectionPool.size() + usedConnections.size(); } public void shutdown() throws SQLException { usedConnections.forEach(this::releaseConnection); for (Connection c : connectionPool) { c.close(); } connectionPool.clear(); } } ``` 接下来,我们来解释一下上面的代码: - `jdbcUrl`、`username` 和 `password` 存储了数据库连接的信息。 - `connectionPool` 存储了可用的连接,`usedConnections` 存储了当前正在使用的连接。 - `INITIAL_POOL_SIZE` 是连接池的默认大小,可以根据需要进行修改。 - 在连接池的构造函数中,我们创建了一定数量的连接,并将它们存储在连接池中。 - `getConnection()` 方法从连接池中获取一个可用的连接,如果连接池为空,则返回 `null`。 - `releaseConnection()` 方法将一个连接释放回连接池中。 - `getSize()` 方法返回连接池的大小。 - `shutdown()` 方法关闭连接池中的所有连接,并清空连接池和正在使用的连接列表。 接下来,我们可以编一个测试类来测试连接池的实现: ```java import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; public class TestConnectionPool { public static void main(String[] args) { String jdbcUrl = "jdbc:mysql://localhost:3306/test"; String username = "root"; String password = "password"; ConnectionPool connectionPool = new ConnectionPool(jdbcUrl, username, password); // Get a connection from the pool Connection connection = connectionPool.getConnection(); try { PreparedStatement preparedStatement = connection.prepareStatement("SELECT * FROM users"); ResultSet resultSet = preparedStatement.executeQuery(); while (resultSet.next()) { System.out.println(resultSet.getString("username")); } } catch (SQLException e) { System.err.println(e.getMessage()); } // Release the connection back to the pool connectionPool.releaseConnection(connection); // Shutdown the connection pool try { connectionPool.shutdown(); } catch (SQLException e) { System.err.println(e.getMessage()); } } } ``` 在上面的测试类中,我们首先创建了一个连接池对象,并从中获取一个连接。然后,我们使用该连接执行一个查询,并将结果打印到控制台。最后,我们将连接释放回连接池中,并关闭连接池。 希望这可以帮助您开始编自己的数据库连接池实现!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值