flink 批量写clickhouse

idea maven 依赖

<dependency>

<groupId>ru.yandex.clickhouse</groupId>

<artifactId>clickhouse-jdbc</artifactId>

<version>0.2.4</version>

</dependency>

val clickhouseUri = "jdbc:clickhouse://host:8123/aso?user=root&password=XXX"

val table =""

processed.addSink(

JdbcSink.sink(

"insert into $table values(?,?)",

CKSinkBuilder(),

JdbcExecutionOptions.Builder()

.withBatchIntervalMs(20000)

.withBatchSize(20000).build(), //20s一批或20000条数据,那个先达到都执行sink

JdbcConnectionOptions.JdbcConnectionOptionsBuilder()

.withUrl(clickhouseUri)

.withDriverName("ru.yandex.clickhouse.ClickHouseDriver")

.build()

)

)

class CKSinkBuilder : JdbcStatementBuilder<DemoData> {

override fun accept(ps: PreparedStatement, v: DemoData) {

ps.setLong(1, v.ts!!)

ps.setSTring(2, v.data!!)

//还有其他字段接着set ps.setSTring(3, v.XXX!!)

}

}

class DemoData{

var ts: Long? = null

var data: String? = null

}

相关推荐
shoubepatien5 分钟前
JavaWeb_Maven
java·maven
逸风尊者7 分钟前
开发可掌握的知识:推荐系统
java·后端·算法
山沐与山8 分钟前
【Flink】Flink编程模型:DataStream与DataSet
大数据·flink
名誉寒冰8 分钟前
深入理解fd_set:从基础到实战应用(Linux/C++)
java·linux·c++
面向Google编程9 分钟前
Flink源码阅读:如何生成ExecutionGraph
大数据·flink
CodeAmaz9 分钟前
RocketMQ怎么保证消息不丢失详解
java·rocketmq·java-rocketmq
灵魂猎手16 分钟前
Antrl4 入门 —— 使用Antrl4实现一个表达式计算器
java·后端
zhonghua88101622 分钟前
spring ai alibab agent之ReactAgent深度解读
java·人工智能·spring
水坚石青25 分钟前
Java+Swing+Mysql实现物业管理系统
java·开发语言·数据库·mysql·swing
尼古拉斯·纯情暖男·天真·阿玮26 分钟前
[JavaEE初阶] Thread类的基本用法
java·开发语言