ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

hive sql中的四个by

2022-05-09 12:33:37  阅读:209  来源: 互联网

标签:sort reducer distribute hive cluster sql 四个 排序 id


1.order by col_list:
   全局排序,默认为升序asc ,因此只有一个reducer,只有一个reduce task的结果,

  比如文件名是000000_0,会导致当输入规模较大时,需要较长的计算时间。

  如果指定了hive.mapred.mode=strict(默认值是nonstrict),这时就必须指定limit来限制输出条数,

  原因是:所有的数据都会在同一个reducer端进行,数据量大的情况下可能不能出结果,那么在这样的严格模式下,必须指定输出的条数。 对被排序列进行全排序,且只启动一个MR任务。

2.sort by col_list :

  局部排序,其在数据进入reducer前完成排序。因此,如果用sort by 进行排序,并且设置mapred.reduce.tasks>1,

  则sort by 只保证每个reducer的输出有序,不保证全局排序。

  在每一个reducetask中,每一个小的输出结果排序,但是当reducetask的个数为1的话和order by 的排序结果一致

注意:sort by 指定的字段仅仅是用于排序的字段,不用于分reducetask输出结果,最终的输出文件中的结果是随机生成的

3.distribute by col_list:

  根据指定的字段将数据分到不同的reducer,且分发算法是hash散列

  类似于分桶的概念 按照指定的distribute by 字段和 设置的reducetask的个数进行取余分组,但是并没有排序,只是分,没有排序

  select * from stu_test distribute by age desc; 错误,不能使用desc,因为它不是排序的意思

4.cluster by col_list :

  除了具有distribute by 的功能外,还会对该字段进行排序

  cluster by = distribute by+sort by

  cluster by id = distribute by id +sort by id

注意:1)cluster by 和sort by 不可以同时使用

2)当分组字段和排序字段是同一个字段的时候 cluster by id = distribute by id +sort by id

不是同一个字段的时候 请不要使用 cluster by id

 

详细见:https://blog.csdn.net/qq_40839450/article/details/106461393

标签:sort,reducer,distribute,hive,cluster,sql,四个,排序,id
来源: https://www.cnblogs.com/qianmojie/p/16248745.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有