Hive中Order by和Sort by的区别是什么?
来源:互联网 发布:淘宝送货入户怎么设置 编辑:程序博客网 时间:2024/05/18 19:37
http://www.crazyant.net/1456.html
Hive基于HADOOP来执行分布式程序的,和普通单机程序不同的一个特点就是最终的数据会产生多个子文件,每个reducer节点都会处理partition给自己的那份数据产生结果文件,这导致了在HADOOP环境下很难对数据进行全局排序,如果在HADOOP上进行order by全排序,会导致所有的数据集中在一台reducer节点上,然后进行排序,这样很可能会超过单个节点的磁盘和内存存储能力导致任务失败。
一种替代的方案则是放弃全局有序,而是分组有序,比如不求全百度最高的点击词排序,而是求每种产品线的最高点击词排序。
使用order by会引发全局排序
select * from baidu_click order by click desc;
使用distribute和sort进行分组排序
select * from baidu_click distribute by product_line sort by click desc;
distribute by + sort by就是该替代方案,被distribute by设定的字段为KEY,数据会被HASH分发到不同的reducer机器上,然后sort by会对同一个reducer机器上的每组数据进行局部排序。
order by是全局有序而distribute+sort是分组有序
distribute+sort的结果是按组有序而全局无序的,输入数据经过了以下两个步骤的处理:
1) 根据KEY字段被HASH,相同组的数据被分发到相同的reducer节点;
2) 对每个组内部做排序
由于每组数据是按KEY进行HASH后的存储并且组内有序,其还可以有两种用途:
1) 直接作为HBASE的输入源,导入到HBASE;
2) 在distribute+sort后再进行orderby阶段,实现间接的全局排序;
不过即使是先distribute by然后sort by这样的操作,如果某个分组数据太大也会超出reduce节点的存储限制,常常会出现137内存溢出的错误,对大数据量的排序都是应该避免的。
- Hive中Order by和Sort by的区别是什么?
- Hive中Order by和Sort by的区别是什么?
- Hive中Order by和Sort by的区别是什么?
- Hive中Order by和Sort by的区别是什么?
- Hive中Order by和Sort by的区别是什么?
- hive中order by、distribute by、sort by和cluster by的区别和联系
- hive 中order by 与 sort by 的区别
- hive中order by,sort by,distribute by,Cluster By的区别
- Hive中order by,sort by,distribute by,cluster by的区别
- Hive中order by,sort by,distribute by,cluster by的区别
- Hive中order by,sort by,distribute by,cluster by的区别
- Hive中order by,sort by,distribute by,cluster by的区别
- Hive中order by,sort by,distribute by,cluster by的区别
- Hive中order by、sort by、distribute by、cluster by的区别
- hive中order by 和sort by与distribute by
- hive 中 Order by, Sort by ,Dristribute by,Cluster By 的作用和用法
- hive 中 Order by, Sort by ,Dristribute by,Cluster By 的作用和用法
- hive 中 Order by, Sort by ,Dristribute by,Cluster By 的作用和用法
- 黑马程序员-File-File方法
- 123
- Validate Binary Search Tree
- UML类图几种关系的总结
- 已经清空了垃圾箱怎样找回误删的文件
- Hive中Order by和Sort by的区别是什么?
- Linux 安装jdk-7u45-linux-x64.tar.gz
- HDU2519(求组合数,数据类型坑)
- Java中的强引用,软引用,弱引用和虚引用
- 玩转安卓带logo的二维码
- Minimum Path Sum
- 工欲善其事,必先利其器 – 网络抓包
- Spring整合Junit4测试
- TI CC2530(DMA编程——手动触发DMA传送,一个数组拷贝到另一个数组里)