hive union all 的烦恼

谨记:union all 只检查前后表的字段类型在顺序上一致,不会检查别称是否一致

 

愚蠢的处理:

昨天,重另一个哥们接过一段SQL(SQL篇幅很大),需要在一天内将该段SQL的逻辑移植更换我现有的简单处理,草草看过SQL,然后干别的事情去了。

半天后,稍稍整理了一下那段SQL,发现通过抽层,可以很好的把这段SQL嵌入到我现有的代码,SQL改动不大。一顿修改,很快可以执行成功了。

于是,简单的补了几天数据,就给测试了。

 

结果。。。数据误差很大。。。

 

检查了半天逻辑,完全没有问题,compare了两个版本SQL,也没有太多误差。。。

纳闷,union all ,仔细比较union all 前后数据,结果,发现我的数据刚好等于原有逻辑的前表。

那么是后表不见了。。。

后表,开始检查后表,逻辑没有问题,单独执行存在数据

仔细比较字段,顺序不同。。。

是的,,,union all的前后表字段顺序应该保持一致。

一切的记忆都开始回来的,这个问题希望不要再犯傻了

转载于:https://www.cnblogs.com/qq1144054302/p/11004054.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值