blinksql 通过维表关联redis 实现hash结构的数据关联

1、相关sql如下:


CREATE TABLE source_table (
  --必须和Kafka源表中的5个字段的顺序保持一致。
  messageKey VARBINARY,
  `message` VARBINARY,
  `topic` VARCHAR,
  `partition` INT,
  `offset` BIGINT
) WITH (
  `type` = 'kafka011',
  `topic` = 'flink005',
  `group.id` = 'kafka_test_wpp',
  `bootstrap.servers` = 'xxxx:9092,xxxx:9092,xxxx:9092'
 -- `startupMode` = 'TIMESTAMP'
);


create view source_table1 as 
SELECT 
cast(`message` as VARCHAR ) msg 
from source_table;


create table redis_dim (
    id VARCHAR,
    val VARCHAR,
    PRIMARY KEY (id), 
    PERIOD FOR SYSTEM_TIME
  ) with (
  type = 'redis',
  host = 'xxxx.redis.rds.aliyuncs.com',
  port = '6379',
  dbNum = '0',
  password = 'xxxx',
  hashName='hkeyvalue'
);


create table sink_print2(
    msg varchar,
    redisval VARCHAR
)with(
    type='print'
);


insert into sink_print2 
SELECT 
e.msg, 
cast(w.val as VARCHAR ) as redisval
from source_table1 as e left join redis_dim FOR SYSTEM_TIME AS OF PROCTIME() AS w
on e.msg = w.id
; 

2、kafka的数据如下:

3、redis的维表数据

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值