Impala中变相实现删除和更新

通用的删除SQL语句:

delete from ODS_DPFM02 a 

where exists (

  select 1 from ODS_DPFM18 d 

  where a.DM02ACCT = d.DM18ACCT 

  and a.DM02ACCS = d.DM18ACCS

);


通用的更新SQL语句:

update ODS_DPFM02 a set a.DM02BALE = (

  select d.DM18REAMT from ODS_DPFM18 d 

  where a.DM02ACCT = d.DM18ACCT 

  and a.DM02ACCS = d.DM18ACCS

);


修改后的Impala中的删除SQL语句:

Insert overwrite table ODS_DPFM02 PARTITION (DM02NODE) 

select a.* from ODS_DPFM02 a 

where not exists (

  select 1 from ODS_DPFM18 d 

  where a.DM02ACCT = d.DM18ACCT 

  and a.DM02ACCS = d.DM18ACCS

);

注:select a.* from ODS_DPFM02 ....结果是0条时,由于该语句是动态分区的方式覆盖插入,系统找不到需要插入的分区,所以表中的数据依旧不变(也就是没有达到清空的效果)。结果是0条时只对不是分区表有效,或指定区分的表有效(分区依然在只是该分区中的数据清零了)。


修改后的Impala中的更新SQL语句:

Insert overwrite table ODS_DPFM02 PARTITION (DM02NODE) 

select t.* from (

  select a.DM02ACCT,

          a.DM02ACCS,

          a.DM02CCY,

          d.DM18REAMT as DM02BALE,

          a.DM02NODE

  from ODS_DPFM02 a 

  join ODS_DPFM18 d 

  on a.DM02ACCT = d.DM18ACCT 

  and a.DM02ACCS = d.DM18ACCS 

UNION ALL 

  select a.* 

  from ODS_DPFM02 a 

  where not exists (

      select 1 from ODS_DPFM18 d 

      where a.DM02ACCT = d.DM18ACCT 

      and a.DM02ACCS = d.DM18ACCS

  )

) t;


注:当然Impala与Hbase关联表也能变相的实现更新,相同Rowkey的数据插入时,会自动覆盖原有的列族的值。



  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值