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

}

相关推荐
2301_8012522210 分钟前
Tomcat的基本使用作用
java·tomcat
lkbhua莱克瓦2411 分钟前
Java基础——常用算法3
java·数据结构·笔记·算法·github·排序算法·学习方法
麦麦鸡腿堡19 分钟前
Java_TreeSet与TreeMap源码解读
java·开发语言
教练、我想打篮球34 分钟前
05 kafka 如何存储较大数据记录
java·kafka·record
uesowys39 分钟前
华为OD算法开发指导-简易内存池
java·算法·华为od
gladiator+39 分钟前
Java中的设计模式------策略设计模式
java·开发语言·设计模式
期待のcode1 小时前
Dockerfile镜像构建
java·docker·容器
小满、1 小时前
对象住哪里?——深入剖析 JVM 内存结构与对象分配机制
java·jvm·#java对象分配·#hotspot实现
How_doyou_do1 小时前
模态框的两种管理思路
java·服务器·前端
m0_748248021 小时前
C++ 异常处理全解析:从语法到设计哲学
java·c++·word