以下是在Linux中使用Apache Commons DBCP实现数据库连接池的简单示例:
1. 首先在项目中引入Apache Commons DBCP的依赖包。可以通过Maven等构建工具引入依赖。
2. 创建数据库连接池对象,并设置连接数据库的相关参数,如数据库URL、用户名、密码等。
3. 通过数据库连接池对象获取数据库连接,执行数据库操作。
4. 在程序结束时释放数据库连接,以便连接池可以重复利用连接。
示例代码如下:
```java
import org.apache.commons.dbcp2.BasicDataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class DBConnectionPool {
private static BasicDataSource dataSource;
static {
dataSource = new BasicDataSource();
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/test");
dataSource.setUsername("username");
dataSource.setPassword("password");
dataSource.setInitialSize(5);
dataSource.setMaxTotal(10);
}
public static Connection getConnection() throws SQLException {
return dataSource.getConnection();
}
public static void closeConnection(Connection conn, PreparedStatement pstmt, ResultSet rs) {
try {
if (rs != null) {
rs.close();
}
if (pstmt != null) {
pstmt.close();
}
if (conn != null) {
conn.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try {
conn = DBConnectionPool.getConnection();
pstmt = conn.prepareStatement("SELECT * FROM users");
rs = pstmt.executeQuery();
while (rs.next()) {
System.out.println(rs.getString("username"));
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
DBConnectionPool.closeConnection(conn, pstmt, rs);
}
}
}
```
在这个示例中,我们使用Apache Commons DBCP创建了一个数据库连接池对象,并通过getConnection方法获取数据库连接,执行SQL查询操作。在程序结束时通过closeConnection方法释放连接。
通过使用数据库连接池,我们可以提高数据库操作的性能和效率,避免频繁创建和销毁数据库连接,减少数据库连接的资源消耗。