flink jdbc实战

本文详细介绍了如何使用Apache Flink进行JDBC操作,包括数据源配置、数据读写及实战案例,深入理解Flink在大数据处理中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class MySinkUtil {
    
    public static <T> SinkFunction<T> getClickHouseSink(String db,
                                                                   String table,
                                                                   Class<T> tClass) {
        
        String url = "jdbc:clickhouse://hadoop162:8123/" + db;
        String driver = "ru.yandex.clickhouse.ClickHouseDriver";
        
        // insert into visitor_stats_2021(c1, c2, c3,...) values(?,?,?...)
        StringBuilder sql = new StringBuilder();
        sql.append("insert into ").append(table).append("(");
        // TODO
        final Field[] fields = tClass.getDeclaredFields();
        for (Field field : fields) {
            // 如果属性被transient修饰, 则表示不会写入到ClickHouse中
            if (field.getAnnotation(TransientSink.class) == null) {
                final String fieldName = field.getName();
                sql.append(fieldName).append(",");
            }
        }
        // 去掉最后一个逗号
        sql.deleteCharAt(sql.length() - 1);
        sql.append(" ) values ( ");
        for (Field field : fields) {
            if (field.getAnnotation(TransientSink.class) == null) {
                sql.append("?,");
            }
        }
        sql.deleteCharAt(sql.length() - 1);
        sql.append(" )");
        
        return getJDBCSink(url, driver, sql.toString());
    }
    
    public static <T> SinkFunction<T> getJDBCSink(String url,
                                                  String driver,
                                                  String sql) {
        // jdbc connector 只支持sink
        return JdbcSink.<T>sink(sql,
                                new JdbcStatementBuilder<T>() {
                                    @Override
                                    public void accept(PreparedStatement ps,
                                                       T t) throws SQLException {
                                        // 3种获取class:  A.class  Class.forName(字符串类名)  对象.getClass
                                        final Field[] fields = t.getClass().getDeclaredFields();
                                        try {
                                            for (int i = 0, position = 1; i < fields.length; i++) {
                                                if (fields[i].getAnnotation(TransientSink.class) == null) {
                                                    fields[i].setAccessible(true);
                                                    ps.setObject(position++, fields[i].get(t));
                                                }
                                            }
                                        } catch (IllegalAccessException e) {
                                            e.printStackTrace();
                                        }
                                    }
                                },
                                new JdbcConnectionOptions.JdbcConnectionOptionsBuilder()
                                    .withUrl(url)
                                    .withDriverName(driver)
                                    .build());
    }
    
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值