|
1 | 1 | package com.clickhouse.examples.jdbc; |
2 | 2 |
|
3 | 3 |
|
| 4 | +import com.clickhouse.jdbc.ClickHouseDataSource; |
| 5 | +import com.zaxxer.hikari.HikariConfig; |
| 6 | +import com.zaxxer.hikari.HikariDataSource; |
| 7 | + |
4 | 8 | import java.sql.Connection; |
5 | 9 | import java.sql.Date; |
6 | 10 | import java.sql.DriverManager; |
@@ -53,5 +57,31 @@ public static void main(String[] args) { |
53 | 57 | } catch (SQLException e) { |
54 | 58 | e.printStackTrace(); |
55 | 59 | } |
| 60 | + |
| 61 | + try { |
| 62 | + //Using HikariCP with ClickHouseDataSource |
| 63 | + usedPooledConnection(url, properties); |
| 64 | + } catch (SQLException e) { |
| 65 | + e.printStackTrace(); |
| 66 | + } |
| 67 | + } |
| 68 | + |
| 69 | + static void usedPooledConnection(String url, Properties properties) throws SQLException { |
| 70 | + // connection pooling won't help much in terms of performance, |
| 71 | + // because the underlying implementation has its own pool. |
| 72 | + // for example: HttpURLConnection has a pool for sockets |
| 73 | + HikariConfig poolConfig = new HikariConfig(); |
| 74 | + poolConfig.setConnectionTimeout(5000L); |
| 75 | + poolConfig.setMaximumPoolSize(20); |
| 76 | + poolConfig.setMaxLifetime(300_000L); |
| 77 | + poolConfig.setDataSource(new ClickHouseDataSource(url, properties)); |
| 78 | + |
| 79 | + try (HikariDataSource ds = new HikariDataSource(poolConfig); |
| 80 | + Connection conn = ds.getConnection(); |
| 81 | + Statement s = conn.createStatement(); |
| 82 | + ResultSet rs = s.executeQuery("SELECT 123")) { |
| 83 | + System.out.println(rs.next()); |
| 84 | + System.out.println(rs.getInt(1)); |
| 85 | + } |
56 | 86 | } |
57 | 87 | } |
0 commit comments