美文网首页
【Hive】数据抽样

【Hive】数据抽样

作者: Yobhel | 来源:发表于2021-12-11 15:13 被阅读0次

数据抽样的常用三种方法

1、随机抽样(rand()函数)

2、数据块抽样(tablesample()函数)

1、随机抽样(rand()函数)

方法一:order by 与 rand 函数结合

limit关键字限制抽样返回的数据
案例:order by 全局排序耗时长

select * from table_name order by rand() limit 100;

方法二:distribute 和 sort 与 rand 函数结合

limit关键字限制抽样返回的数据
案例:rand函数前的distribute和sort关键字可以保证数据在mapper和reducer阶段是随机分布的

select * from table_name where datekey='2020-11-26' 
distribute by rand() sort by rand() limit 100;

2、数据块抽样(tablesample()函数)

方法一:百分比(percent)

  • 语法:tablesample(n percent)
  • 功能:根据 hive 表数据的大小按比例抽取数据。如:抽取原 hive 表中 10%的数据
  • 案例:
select * from table_name tablesample(10 percent);
select * from table_name tablesample(10 percent) where month =202202;

方法二:大小(m)

  • 语法:tablesample(n M)
  • 功能:指定抽样数据的大小,单位为 M。
  • 案例:
select * from table_name tablesample(1M);

方法三:行数(rows)

  • 语法:tablesample(n rows)
  • 功能:指定抽样数据的行数,其中 n 代表每个 map 任务均取 n 行数据,map 数量可通过 hive 表的简单查询语句确认(关键词:number of mappers: x)
  • 案例:
    不指定where条件,用时374ms
  select * from table_name tablesample(5 rows) ;

指定where条件,用时36s,而且可以看出是tablesample函数是在where条件之前生效的~

select * from table_name tablesample(5 rows) where gender='F';

方法四:分桶抽样

hive中分桶其实就是根据某一个字段Hash取模,放入指定数据的桶中,比如将表table_1按照ID分成100个桶,其算法是hash(id) % 100,这样,hash(id) % 100 = 0的数据被放到第一个桶中,hash(id) % 100 = 1的记录被放到第二个桶中。创建分桶表的关键语句为:CLUSTER BY语句。
分桶抽样语法:

  • 语法:TABLESAMPLE (BUCKET x OUT OF y [ON colname])
  • 功能:分桶抽样,其中 x 是要抽样的桶编号,桶编号从 1 开始,colname 表示抽样的列,y 表示桶的数量。
  • 案例:
select * from table_name tablesample(bucket 1 out of 10 on rand());

相关文章

  • 2019-03-12-Hive的数据抽样

    最近在做Hive的数据抽样,基于以下考虑: 效率:数据量大的时候,可以给Hive 的使用者提供抽样数据,供他们开发...

  • 【Hive】数据抽样

    数据抽样的常用三种方法 1、随机抽样(rand()函数)[#1rand_1] 方法一:order by 与 ran...

  • 大数据开发之Hive优化篇4-Hive的数据抽样-Samplin

    备注:Hive 版本 2.1.1 抽样概述 当数据量特别大时,对全体数据进行处理存在困难时,抽样就显得尤其重要了。...

  • 使用Hive随机抽样

    1 在hive中使用rand简单随机抽样 2、数据块取样(Block Sampling)--来源于网路 系统抽样 ...

  • Hive进阶—抽样的各种玩法

    抽样 抽样在Hive 中也是比较常用的一种手段,主要用在下面的几个场景中 一些机器学习的场景中,数仓作为数据的提供...

  • 数据抽样

    每天抽取 %5

  • 统计

    抽样采集数据:概率抽样和非概率抽样概率抽样也称为随机抽样,是指遵守随机原则进行的抽样,总体中每个单位都有一定的机会...

  • Hive 基础

    Hive 基础 Hive启动: 插入数据: 插入数据文件: Hive交互命令: 参数配置方式: hive> set...

  • 3 流数据挖掘

    1、流数据挖掘课程中介绍了几个主要的功能:1)抽样,2)过滤 3)计数1)抽样:对于大量的数据进行抽样,如果抽取固...

  • Hive学习-Hive基本操作(建库、建表、分区表、写数据)

    hive简单认识 Hive是建立在HDFS之上的数据仓库,所以Hive的数据全部存储在HDFS上。Hive的数据分...

网友评论

      本文标题:【Hive】数据抽样

      本文链接:https://www.haomeiwen.com/subject/jsvkfrtx.html