Flink SQL 处理json对象数组,列变多行

数据格式:

{
    "s_time": "2022-05-11 11:01:49.254",
    "que_id": "5a8fb527-82a7-4e33-91a1-55ec86cacbe4",
    "count": 2,
    "data": [
      {
        "code": "dd",
        "dealtime": "2022-05-11 22:01:49.240"
      },
      {
        "code": "dd",
        "dealtime": "2022-05-11 22:01:49.240"
      }
}

sql:

--连接kafka
create table kafkastream ( 
    `source_time` string,
    queue_id string,
    `count` bigint,
    `data` ARRAY<ROW<code string, dealtime string>>,
    proctime as PROCTIME(),
    ts TIMESTAMP(3),
    WATERMARK FOR ts AS ts - INTERVAL '2' SECOND
)
with ( 
    'connector' = 'kafka',
    'topic' = 'test_3',
    'properties.group.id' = 'test3',
    'scan.startup.mode' = 'latest-offset',
    'format' = 'json',
    'json.fail-on-missing-field' = 'false'
);
--处理
select
     code,
     DATE_FORMAT(dealtime, 'yyyyMMdd') as date
     proctime,
     ts
from
     kafkastream CROSS JOIN UNNEST(`data`) AS t (code,dealtime)
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值