iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Hive的静态分区与动态分区的区别
  • 177
分享到

Hive的静态分区与动态分区的区别

2023-06-02 01:06:11 177人浏览 八月长安
摘要

本篇内容介绍了“Hive的静态分区与动态分区的区别”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  1. 静态分区:若分区的值是确定的,那么

本篇内容介绍了“Hive的静态分区与动态分区的区别”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

  1. 静态分区:若分区的值是确定的,那么称为静态分区。新增分区或者是加载分区数据时,已经指定分区名。

  create table if not exists day_part1(

  uid int,

  uname string

  )

  partitioned by(year int,month int)

  row fORMat delimited fields terminated by '\t';

  ##加载数据指定分区

  load data local inpath '/root/Desktop/student.txt' into table day_part1

partition(year=2017,month=04);

  ##新增分区指定分区名

  alter table day_part1 add partition(year=2017,month=1)

partition(year=2016,month=12);

  2. 动态分区:分区的值是非确定的,由输入数据来确定

  2.1 动态分区的相关属性:

  hive.exec.dynamic.partition=true :是否允许动态分区

  hive.exec.dynamic.partition.mode=strict :分区模式设置

  strict:最少需要有一个是静态分区

  nostrict:可以全部是动态分区

  hive.exec.max.dynamic.partitions=1000 :允许动态分区的最大数量

  hive.exec.max.dynamic.partitions.pernode =100

:单个节点上的mapper/reducer允许创建的最大分区

  2.2 动态分区的操作

  ##创建临时表

  create table if not exists tmp

  (uid int,

  commentid bigint,

  recommentid bigint,

  year int,

  month int,

  day int)

  row format delimited fields terminated by '\t';

  ##加载数据

  load data local inpath '/root/Desktop/comm' into table tmp;

  ##创建动态分区表

  create table if not exists dyp1

  (uid int,

  commentid bigint,

  recommentid bigint)

  partitioned by(year int,month int,day int)

  row format delimited fields terminated by '\t';

  ##严格模式

  insert into table dyp1 partition(year=2016,month,day)

  select uid,commentid,recommentid,month,day from tmp;

  ##非严格模式

  ##设置非严格模式动态分区

  set hive.exec.dynamic.partition.mode=nostrict;

  ##创建动态分区表

  create table if not exists dyp2

  (uid int,

  commentid bigint,

  recommentid bigint)

  partitioned by(year int,month int,day int)

  row format delimited fields terminated by '\t';

  ##为非严格模式动态分区加载数据

  insert into table dyp2 partition(year,month,day)

  select uid,commentid,recommentid,year,month,day from tmp;

  3.分区注意细节

  (1)、尽量不要用动态分区,因为动态分区的时候,将会为每一个分区分配reducer数量,当分区数量多的时候,reducer数量将会增加,对服务器是一种灾难。

  (2)、动态分区和静态分区的区别,静态分区不管有没有数据都将会创建该分区,动态分区是有结果集将创建,否则不创建。

  (3)、hive动态分区的严格模式和hive提供的hive.mapred.mode的严格模式。

  hive提供我们一个严格模式:为了阻止用户不小心提交恶意hql

  hive.mapred.mode=nostrict : strict

  如果该模式值为strict,将会阻止以下三种查询:

  (1)、对分区表查询,where中过滤字段不是分区字段。

  (2)、笛卡尔积join查询,join查询语句,不带on条件或者where条件。

  (3)、对order by查询,有order by的查询不带limit语句。

“Hive的静态分区与动态分区的区别”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: Hive的静态分区与动态分区的区别

本文链接: https://www.lsjlt.com/news/228346.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Hive的静态分区与动态分区的区别
    本篇内容介绍了“Hive的静态分区与动态分区的区别”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  1. 静态分区:若分区的值是确定的,那么...
    99+
    2023-06-02
  • Hive中的动态分区和静态分区的区别
    Hive中的动态分区和静态分区是两种不同的分区方式,它们的区别在于分区的创建和管理方式。 静态分区:静态分区是在创建表时就定义好的...
    99+
    2024-03-12
    Hive
  • Hive中静态分区与动态分区的示例分析
    这篇文章给大家分享的是有关Hive中静态分区与动态分区的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。  分区是hive存放数据的一种方式。将列值作为目录来存放数据,就是一个分区。这样查询时使用分区列进行...
    99+
    2023-06-02
  • 静态SQL和动态SQL的区别
    静态SQL静态SQL是指那些固定的、可以硬编码到应用程序中的SQL语句。由于静态sql是固定的查询,这些语句可以被分析和优化,不需要出于安全目的进行任何特殊处理。动态SQL动态SQL是指那些不存在的SQL语句。根据用户的输入动态生成并在应用...
    99+
    2023-10-22
  • Hive中怎么实现动态分区
    本篇文章为大家展示了Hive中怎么实现动态分区,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。动态分区调整动态分区属性:设置为true表示开启动态分区功能(默认为fa...
    99+
    2024-04-02
  • Hive中动态轮换分区指的是什么
    在Hive中,动态轮换分区是一种机制,用于在数据加载时自动将数据分发到不同的分区中。这种机制可以使数据加载的过程更加高效和灵活,不需...
    99+
    2024-03-14
    Hive
  • 动态和静态ip有什么区别
    小编给大家分享一下动态和静态ip有什么区别,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、区分动态IP因特网,也叫DHCP因特网。IP互联网自动获取。这种互联网...
    99+
    2023-06-15
  • 动态库和静态库有什么区别
    这篇文章主要介绍“动态库和静态库有什么区别”,在日常操作中,相信很多人在动态库和静态库有什么区别问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”动态库和静态库有什么区别”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-20
  • JAVA中静态代理与动态代理的区别有哪些
    这期内容当中小编将会给大家带来有关JAVA中静态代理与动态代理的区别有哪些,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。代理模式是java中最常用的设计模式之一,尤其是在spring框架中广泛应用。对于j...
    99+
    2023-05-31
    java 静态代理 动态代理
  • 网页开发中静态资源与动态资源的区别
    一、内容变化的区别 静态资源:静态资源通常是预先创建好的,其内容在服务器启动后就已经确定,不会因为用户的请求而改变。如HTML、CSS、JavaScript文件、图片等。 动态资源:动态资源的内容则是在接收到用户请求后,由服务器...
    99+
    2023-10-29
    资源 静态 区别
  • java动态和静态语言的区别是什么
    今天就跟大家聊聊有关java动态和静态语言的区别是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、动态语言在运行中可以改变结构的语言。例如,新函数、对象、代码可以引进,现有函数...
    99+
    2023-06-15
  • 动态网站和静态网站的区别有哪些
    这篇文章主要讲解了“动态网站和静态网站的区别有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“动态网站和静态网站的区别有哪些”吧!网站SEO优化优哪种网站更利于优化呢静态网页是相对于动态网...
    99+
    2023-06-10
  • 动态IP和静态IP的使用区别是什么
    这篇文章主要讲解了“动态IP和静态IP的使用区别是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“动态IP和静态IP的使用区别是什么”吧!伴随着因特网的不断发展,IP代理现在是市场上需求比...
    99+
    2023-06-20
  • vps动态ip和静态ip有什么区别
    vps动态ip和静态IP的区别:vps动态ip在连接网络时会自动获取IP地址以供用户正常上网,而静态ip是ISP在装机时分配给用户的...
    99+
    2023-02-08
    vps动态ip vps
  • mfc静态库和动态库有什么区别
    静态库和动态库的区别在于它们在编译时和链接时的处理方式不同。 静态库是在编译时被链接到目标文件中,因此编译后的可执行文件会包...
    99+
    2024-03-02
    mfc
  • linux中动态库和静态库的区别有哪些
    这篇文章将为大家详细讲解有关linux中动态库和静态库的区别有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。区别:1、静态库在程序编译时会被连接到目标代码中,程序运行时将不再需要该静态库;动态库在程序...
    99+
    2023-06-25
  • 静态和动态sql之间有哪些区别
    小编给大家分享一下静态和动态sql之间有哪些区别,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!静态或嵌入式 SQL是应用程序中的...
    99+
    2024-04-02
  • C#静态变量和非静态变量的区别
    本篇内容介绍了“C#静态变量和非静态变量的区别”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!C#基础概念之一,静态变量和非静态变量的区别?静...
    99+
    2023-06-18
  • mysql中静态表和动态表的区别是什么
    今天就跟大家聊聊有关mysql中静态表和动态表的区别是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 静态表字段长度固定,自动填充,读写速度很...
    99+
    2024-04-02
  • C#中静态变量与非静态变量的区别有哪些
    这篇文章主要为大家展示了“C#中静态变量与非静态变量的区别有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C#中静态变量与非静态变量的区别有哪些”这篇文章吧。静态变量:静态变量使用 stat...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作