hive select语句输出指定分隔符

Hive0.11.0版本新引进了一个新的特性,也就是当用户将 Hive查询结果输出到文件,用户可以指定列的分割符,而在之前的版本是不能指定列之间的分隔符,这样给我们带来了很大的不变,在Hive0.11.0之前版本我们一般是这样用的:
1hive> insert overwrite local directory '/home/wyp/Documents/result'
2hive> select * from test;

保存的文件列之间是用^A(\x01)来分割

1196^A242^A3
2186^A302^A3
322^A377^A1
4244^A51^A2

注意,上面是为了显示方便,而将\x01写作^A,在实际的文本编辑器我们是看不到^A的,而是一个奇怪的符号。
  现在我们可以用Hive0.11.0版本新引进了一个新的特性,指定输出结果列之间的分隔符:

1hive> insert overwrite local directory '/home/wyp/Documents/result'
2hive> row format delimited
3hive> fields terminated by '\t'
4hive> select * from test;

再次看出输出的结果

1196 242 3
2186 302 3
322  377 1
4244 51  2

结果好看多了。如果是map类型可以用下面语句来分割map的key和value

1hive> insert overwrite local directory './test-04'
2hive> row format delimited
3hive> FIELDS TERMINATED BY '\t'
4hive> COLLECTION ITEMS TERMINATED BY ','
5hive> MAP KEYS TERMINATED BY ':'
6hive> select * from src;
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值