Hive分区表的导入与导出

最近在做一个小任务,将一个CDH平台中Hive的部分数据同步到另一个平台中。毕竟我也刚开始工作,在正式开始做之前,首先进行了一段时间的练习,下面的内容就是练习时写的文档中的内容。如果哪里有错误或者疏漏,希望各位网友能够指出。

第一篇:HDFS的上传与下载:https://www.cnblogs.com/BlackString/p/10552553.html

第二篇:Hive中数据的导入与导出:https://www.cnblogs.com/BlackString/p/10552806.html

第四篇:跨平台传输方案:https://www.cnblogs.com/BlackString/p/10553010.html

Hive分区表数据的上传与导出

1. 前言
? 经过前两篇的练习,我们练习了文件的上传与下载,以及Hive外部表数据的上传与导出。但是很多时候Hive的数据操作不仅仅是外部表,还有可能是对分区表的操作。接下来,就对分区表的数据操作进行练习。

2. 分区表的文件结构

  1)创建一个分区表,分区字段为country:
    hive> create table tt01(id int, name string) partitioned by(country string);

  2)插入几条新数据:
    hive> insert into tt01 partition(country=‘CN‘) values(1,‘LS‘);
    hive> insert into tt01 partition(country=‘CN‘) values(2,‘ZS‘);
    hive> insert into tt01 partition(country=‘US‘) values(3,‘Alice‘);
    hive> insert into tt01 partition(country=‘UK‘) values(4,‘Tom‘);

  3)到hive中查看表中的数据:
    hive> select from tt01;
    1 LS CN
    2 ZS CN
    3 Alice US
    4 Tom UK

4)到HDFS中查看test02.db中,tt01文件夹下的文件:
    [root@DataCenter2 aos_dic]# hadoop fs -ls /user/hive/warehouse/test02.db/tt01
    drwxrwxrwt - root hive 0 2019-03-15 10:50 /user/hive/warehouse/test02.db/tt01/country=CN
    drwxrwxrwt - root hive 0 2019-03-15 10:46 /user/hive/warehouse/test02.db/tt01/country=UK
    drwxrwxrwt - root hive 0 2019-03-15 10:45 /user/hive/warehouse/test02.db/tt01/country=US

  会发现Hive按照分区将数据分别存入了不同的文件夹下。
  进入某一个分区,查看其中的数据:
    [root@DataCenter2 aos_dic]# hadoop fs -ls /user/hive/warehouse/test02.db/tt01/country=CN
    -rwxrwxrwt 3 root hive 5 2019-03-15 10:43 /user/hive/warehouse/test02.db/tt01/country=CN/000000_0
    -rwxrwxrwt 3 root hive 5 2019-03-15 10:45 /user/hive/warehouse/test02.db/tt01/country=CN/000000_0_copy_1
  其中发现两个文件,查看其中的内容,会发现每个文件中都存了一条数据。那么,是每条数据都生成一个文件吗?

5)向tt01中插入一条新的数据,分区为“CN”:

    hive> insert into tt01 partition(country=‘CN‘) values(5,‘WW‘);
  到tt01文件夹下,country=CN中查看文件,会发现多出了一个新文件,查看这个新文件,发现其中存储的正是我们新插入的数据:
    [root@DataCenter2 aos_dic]# hadoop fs -cat /user/hive/warehouse/test02.db/tt01/country=CN/000000_0_copy_2
    5WW

3. 创建一个外部分区表
  接下来,尝试在test02库中建立一个新的外部外部表,并且为其指定分区。
  如何建立一个外部分区表呢?
  最初的想法是,按照文件的格式新建一个表,然后指定分区的名称和文件的位置,这样建立的表应该是包含了我所有的数据的。但是在尝试了多次以后发现,Hive并不能自动识别已经建立好的分区。

  经过查询得知,Hive分区表如果要载入外部分区数据,有两种方式:

  1)手动指定分区并载入数据,如:
    hive> alter table tt02 add partition (birth=‘1997‘) location ‘/hive> msck repair table tt02;

  2)修复分区信息,如:
    hive> msck repair table tt02;
    Partitions not in metastore: tt02:birth=1998 tt02:birth=1999
    Repair: Added partition to metastore tt02:birth=1998
    Repair: Added partition to metastore tt02:birth=1999

  但是以上两种方式并不包含直接建立表载入分区。
  因此,建立一个外部分区表的步骤是:
  1)按照文件数据的格式建立字段,并指定分区字段:
    hive> create external table tt02(id int,name string,gender string) partitioned by (birth string) row format delimited fields terminated by ‘ ‘ location ‘/user/hive/warehouse/test02.db/tt02‘;

  2)新增分区,或 修复分区:
    hive> alter table tt02 add partition (birth=‘1997‘) location ‘/‘
    hive> msck repair table tt02;
    Partitions not in metastore: tt02:birth=1998 tt02:birth=1999
    Repair: Added partition to metastore tt02:birth=1998
    Repair: Added partition to metastore tt02:birth=1999

  3)查看数据:
    hive> select from tt02;
    1 LS m 1997
    2 ZQ m 1997
    3 LG f 1997
    4 ST f 1997
    5 SD m 1997
    …… ……

原文地址:https://www.cnblogs.com/BlackString/p/10552901.html

时间: 2024-10-09 13:23:19

Hive分区表的导入与导出的相关文章

Sqoop_具体总结 使用Sqoop将HDFS/Hive/HBase与MySQL/Oracle中的数据相互导入、导出

一.使用Sqoop将MySQL中的数据导入到HDFS/Hive/HBase 二.使用Sqoop将HDFS/Hive/HBase中的数据导出到MySQL 2.3 HBase中的数据导出到mysql 眼下没有直接的命令将HBase中的数据导出到MySQL.但能够先将HBase中的数据导出到HDFS中.再将数据导出到MySQL. 三.使用Sqoop将Oracle中的数据导入到HDFS/Hive/HBase 以下仅仅给出将Oracle中的数据导入HBase,其它情况下的命令行选项与MySQL的操作相似

详细总结 使用Sqoop将HDFS/Hive/HBase与MySQL/Oracle中的数据相互导入、导出

一.使用Sqoop将MySQL中的数据导入到HDFS/Hive/HBase 二.使用Sqoop将HDFS/Hive/HBase中的数据导出到MySQL 2.3 HBase中的数据导出到mysql 目前没有直接的命令将HBase中的数据导出到MySQL,但可以先将HBase中的数据导出到HDFS中,再将数据导出到MySQL. 三.使用Sqoop将Oracle中的数据导入到HDFS/Hive/HBase 下面只给出将Oracle中的数据导入HBase,其他情况下的命令行选项与MySQL的操作相似 O

hive数据库导入与导出

原文连接:https://www.cnblogs.com/654wangzai321/p/9970321.html 把Hive表数据导入到本地 table->local file insert overwrite local directory '/root/hive_test/1.txt' select * from behavior_table; 把Hive表数据导入到HDFS上 table->hdfs file insert overwrite directory '/root/hive

将Hive统计分析结果导入到MySQL数据库表中(一)——Sqoop导入方式

最近在做一个交通流的数据分析,需求是对于海量的城市交通数据,需要使用MapReduce清洗后导入到HBase中存储,然后使用Hive外部表关联HBase,对HBase中数据进行查询.统计分析,将分析结果保存在一张Hive表中,最后使用Sqoop将该表中数据导入到MySQL中.整个流程大概如下: 下面我主要介绍Hive关联HBase表--Sqoop导出Hive表到MySQL这些流程,原始数据集收集.MapReduce清洗及WEB界面展示此处不介绍. 一.HBase数据库表 hbase(main):

oracle的emp导入imp导出命令

oracle导入导出命令详解(附数据库每天定时备份脚本) 一. 导出工具 exp 1. 它是操作系统下一个可执行的文件 存放目录/ORACLE_HOME/bin exp导出工具将数据库中数据备份压缩成一个二进制系统文件.可以在不同OS间迁移 它有三种模式: a.  用户模式: 导出用户所有对象以及对象中的数据: b.  表模式: 导出用户所有表或者指定的表: c.  整个数据库: 导出数据库中所有对象. 2. 导出工具exp交互式命令行方式的使用的例子 $exp test/[email prot

Postgres数据库中excel的导入和导出

使用Windows系统,excel的总是不可避免. Postgres版本为9.3.6:Windows 8.1 64位. 这里没有找到excel直接导入Postgres的方法,有一个工具是xlstopg,类似SQL Server的导入和导出数据向导,但不是开源的:可以到网上搜下玩玩(好像试用版只能导1000条记录),我在不知名网站上下了个企图是破解版,结果电脑中毒,花了两个晚上时间,电脑才幸而没有重装系统.我只能说有些网站太不是东西了,你说你里面很多插件(游戏的客户端.日历等乱七八糟的东西),我忍

Hive数据导入——数据存储在Hadoop分布式文件系统中,往Hive表里面导入数据只是简单的将数据移动到表所在的目录中!

转自:http://blog.csdn.net/lifuxiangcaohui/article/details/40588929 Hive是基于Hadoop分布式文件系统的,它的数据存储在Hadoop分布式文件系统中.Hive本身是没有专门的数据存储格式,也没有为数据建立索引,只需要在创建表的时候告诉Hive数据中的列分隔符和行分隔符,Hive就可以解析数据.所以往Hive表里面导入数据只是简单的将数据移动到表所在的目录中! Hive的几种常见的数据导入方式这里介绍四种:(1).从本地文件系统中

Docker 容器的导入和导出操作

导出容器 导出容器是指 导出一个已经创建的容器到一个文件,不管此时这个容器是否处于运行状态,可以使用docker export 命令,该命令格式为 docker export CONTAINER. 查看所有容器如下: # docker ps -a CONTAINER ID        IMAGE                COMMAND             CREATED             STATUS                          PORTS       

ECMAScript 6的导入和导出:import 、export

一 基本语法 import { dog , person , hero } from './common.js'; import { hello,Plane } from './common.js'; import { car , rain } from './common.js'; import shrimp from './common.js'; console.log(lottery); console.log(dog,person,hero); hello(); let plane =