直接将文件put到Hdfs后建Hive表查询数据
由于业务需要,有时需要将其他地方的文件数据导入HDFS,然后建Hive表进行数据查询或数据业务统计。这里演示如何将本地文件先put到Hive已存在的空表中,然后查询数据。
CREATE TABLE `hive_test.direct_load_file_into_table`(
`id` int,
`name` string)
PARTITIONED BY (`year` string COMMENT '年', `month` string COMMENT '月', `day` string COMMENT '日')
row format delimited fields terminated by '\t'
STORED AS textfile;
然后show create table,确认下该该表的HDFS路径,比如/user/hive/warehouse/hive_test.db/direct_load_file_into_table
CREATE TABLE `direct_load_file_into_table`(
`id` int,
`name` string)
PARTITIONED BY (
`year` string COMMENT '年',
`month` string COMMENT '月',
`day` string COMMENT '日')
ROW FORMAT SERDE
'org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe'
WITH SERDEPROPERTIES (
'field.delim'='\t',
'serialization.format'='\t')
STORED AS INPUTFORMAT
'org.apache.hadoop.mapred.TextInputFormat'
OUTPUTFORMAT
'org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat'
LOCATION
'hdfs://xxxxxx:9000/user/hive/warehouse/hive_test.db/direct_load_file_into_table'
TBLPROPERTIES (
'transient_lastDdlTime'='1523536404')
这里将本地两个文件,put到上一步所建表的hdfs路径下,同时演示文件夹迭代比如这里除了分区2018/04/01,额外添加了一层文件夹01和02
hadoop fs -mkdir -p /user/hive/warehouse/hive_test.db/direct_load_file_into_table/2018/04/01/01
hadoop fs -mkdir -p /user/hive/warehouse/hive_test.db/direct_load_file_into_table/2018/04/01/02
hadoop fs -ls /user/hive/warehouse/hive_test.db/direct_load_file_into_table/2018/04/01
drwxr-xr-x - hjw01 supergroup 0 2018-04-12 20:12 /user/hive/warehouse/hive_test.db/direct_load_file_into_table/2018/04/01/01
drwxr-xr-x - hjw01 supergroup 0 2018-04-12 20:12 /user/hive/warehouse/hive_test.db/direct_load_file_into_table/2018/04/01/02
本地文件如下
[hjw01@f0d97899be95 data]$ more 01.txt
101 张三
102 李四
103 王五
[hjw01@f0d97899be95 data]$ more 02.txt
201 张三
202 李四
203 王五
将本地文件put到hdfs中
hadoop fs -put 01.txt /user/hive/warehouse/hive_test.db/direct_load_file_into_table/2018/04/01/01
hadoop fs -put 02.txt /user/hive/warehouse/hive_test.db/direct_load_file_into_table/2018/04/01/02
建立分区就可以直接使用分区下的数据
alter table hive_test.direct_load_file_into_table add if not exists partition(year='2018',month='04',day='01') location '2018/04/01';
这里我们顺带演示了文件多层迭代,需要set 参数,具体如下
set hive.mapred.supports.subdirectories=true;
set mapreduce.input.fileinputformat.input.dir.recursive=true;
select
*
from
hive_test.direct_load_file_into_table
where
concat(year,month,day) = '20180401'
查询结果
hive> set hive.mapred.supports.subdirectories=true;
hive> set mapreduce.input.fileinputformat.input.dir.recursive=true;
hive> select
> *
> from
> hive_test.direct_load_file_into_table
> where
> concat(year,month,day) = '20180401';
OK
101 张三 2018 04 01
102 李四 2018 04 01
103 王五 2018 04 01
201 张三 2018 04 01
202 李四 2018 04 01
203 王五 2018 04 01
Time taken: 1.775 seconds, Fetched: 6 row(s)