clickhouse 使用 jdbc 查询 phoenix

本文基于
clickhouse v21.7.3
clickhouse-jdbc-bridge v2.1.0
hbase v2.0.5
phoenix v5.0.0

一、下载clickhouse-jdbc-bridge

下载链接: https://github.com/ClickHouse/clickhouse-jdbc-bridge/releases/tag/v2.1.0

hbase-site.xml 放入resource下,执行maven命令 mvn package -DskipTests 编译打包
在这里插入图片描述

二、在clickhouse服务器上新建目录

在 /var/lib/clickhouse 下新建目录clickhouse-jdbc-bridge/ ,将打好的包上传至该目录下,并在该目录下新建以下两个目录

config/datasources/     用于存放三方库的配置文件,json格式
drivers/				用于存放三方库的驱动

在这里插入图片描述

三、在config/datasources/目录下编写配置文件 phoenix.json

注意图中圈出的名字要与文件名一致在这里插入图片描述

四、将phoenix驱动上传至drivers/目录

五 、运行clickhouse-jdbc-bridge-2.1.0-SNAPSHOT-shaded.jar

执行此命令即可,java -jar clickhouse-jdbc-bridge-2.1.0-SNAPSHOT-shaded.jar

六、此时已配置完成,可在clickhouse里进行查询

在这里插入图片描述

你可以使用JDBC来批量插入数据到ClickHouse数据库。下面是一个简单的示例代码来演示如何使用JDBC批量插入数据: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; public class ClickHouseBatchInsert { public static void main(String[] args) { // JDBC连接信息 String url = "jdbc:clickhouse://localhost:8123/default"; String username = "your_username"; String password = "your_password"; // SQL插入语句 String sql = "INSERT INTO your_table (column1, column2, column3) VALUES (?, ?, ?)"; // 数据集 Object[][] data = { {"value1_1", "value1_2", "value1_3"}, {"value2_1", "value2_2", "value2_3"}, {"value3_1", "value3_2", "value3_3"} }; try (Connection conn = DriverManager.getConnection(url, username, password); PreparedStatement pstmt = conn.prepareStatement(sql)) { // 关闭自动提交 conn.setAutoCommit(false); // 批量插入数据 for (Object[] row : data) { for (int i = 0; i < row.length; i++) { pstmt.setObject(i + 1, row[i]); } pstmt.addBatch(); } // 执行批量插入 int[] result = pstmt.executeBatch(); // 提交事务 conn.commit(); System.out.println("成功插入 " + result.length + " 条数据"); } catch (SQLException e) { e.printStackTrace(); } } } ``` 在这个示例中,你需要将`url`、`username`和`password`替换为你实际的ClickHouse连接信息,将`your_table`替换为你要插入数据的目标表名。然后,根据你的数据集,调整`data`数组中的值和列数。 这个示例中使用了`PreparedStatement`来执行预编译的SQL语句,并使用`addBatch()`方法将批量插入的每一行添加到批处理中。最后,通过调用`executeBatch()`方法执行批处理操作,并使用`commit()`方法提交事务。 这样,你就可以使用JDBC批量插入数据到ClickHouse数据库了。希望对你有所帮助!如果有任何问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值