04-Hive表数据导入和导出

Hive表数据导入

[root@tianqinglong01 hive]# mkdir /hivedata
[root@tianqinglong01 hive]# cd hivedata
[root@tianqinglong01 hivedata]# vi user.txt
1,张三
2,李四
3,王五

hive>create table if not exists t_user(
id int,
name string
)
row format delimited
fields terminated by ','
lines terminated by '\n'
stored as textfile;

加载数据到hive,一般分为两种:

一种是从本地Linux上加载到hive中
另一种是从HDFS加载到hive中

方法一:使用hdfs dfs -put 将本地文件上传到表目录下

hdfs dfs -put ./user.txt  /usr/hive/warehouse/qfdb.db/t_user

方法二:在hive中使用load命令

hive> load data local inpath '/root/user.txt' [overwrite] into table t_user;  #追加 

方式三:

hive>create table if not exists t_user2(
id int,
name string
)
row format delimited
fields terminated by ','
lines terminated by '\n'
stored as textfile;
hive>create table if not exists t_user3(
id int,
name string
)
row format delimited
fields terminated by ','
lines terminated by '\n'
stored as textfile;
hive>create table if not exists t_user4(
id int,
name string
)
row format delimited
fields terminated by ','
lines terminated by '\n'
stored as textfile;

hive> insert into table t_user2 select * from t_user;

#扩展
hive> from t_user
    > insert into t_user3 select *
	> insert into t_user4 select * where id<3;
                                               
                                               
hive> create table t_user5 (id int);
hive> insert into t_user5 select id from t_user;

方法四 :克隆表数据

hive> create table if not exists t_user6 as select * from t_user;

#扩展内容 只复制表结构
hive> create table if not exists t_user7 like t_user;

加载数据的本质:

1,如果数据在本地,加载数据的本质就是将数据copy到hdfs上的表目录下。

2,如果数据在hdfs上,加载数据的本质是将数据移动到hdfs的表目录下。

hive数据导出

--1. 导出数据到本地文件系统的目录下
hive>insert overwirte local directory '/root/out/00'
	>select * from t_user;

--2. 导出数据到hdfs的目录下
hive>insert overwirte directory '/root/out/00'
	>select * from t_user;

---导出的文件字段默认不分隔

--3.修改导出后的列与列之间的格式
hive>insert overwirte directory '/root/out/01'
 	>row format delimited fields terminated by ','
	>select * from t_user;
	
--4.直接导入到本地系统s的文件
[root@tianqinglong01 ~]# hive -e 'select * from qfdb.t_user' >> /root/out/02
#导出的文件字段默认分隔符 '\t'
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值