flinkSql join redis的hash结构维表简单实现

5 篇文章 0 订阅
以下是阿里云的blinksql的demo

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



create table redis_dim (
    id VARCHAR,
    name VARCHAR,
    PRIMARY KEY (id), 
    PERIOD FOR SYSTEM_TIME
  ) with (
  type = 'redis',
  host = '127.0.0.1',
  port = '6379',
  dbNum = '0',
  password = 'pass',
  hashName='hashtest'
);


create table sink_print2(
    mes varchar,
    name VARCHAR
)with(
    type='print'
);



insert into sink_print2 
SELECT 
cast (e.`message` as varchar),
 w.name
from source_table as e left join redis_dim FOR SYSTEM_TIME AS OF PROCTIME() AS w
on cast(e.message as varchar )  = w.id
; 

维表join相关测试案例

flinksql正则表达式

REGEXP_EXTRACT(`acm`, 'cid_\\d+', 0) AS regex_cid2,

REGEXP_EXTRACT(`acm`, '(cid_\\d+)', 1) AS regex_cid3,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值