CREATE TABLE array_data_type(
c_array array<string>)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ','
COLLECTION ITEMS TERMINATED BY '&';
Create data.csv
with data:
arr1&arr2
arr2&arr4
Put data.csv
in /tmp
folderand load this data in Hive
LOAD DATA LOCAL INPATH '/tmp/data.csv' INTO TABLE array_data_type;
Or you can put this CSV in HDFS say at /tmp
. Load data from CSV at HDFS using
LOAD DATA INPATH '/tmp/data.csv' INTO TABLE array_data_type;
CREATE TABLE map_data_type(
c_map map<int,string>)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ','
COLLECTION ITEMS TERMINATED BY '&'
MAP KEYS TERMINATED BY '#';
data.csv
file:
101#map1&102#map2
103#map3&104#map4
Load data into hive:
LOAD DATA LOCAL INPATH '/tmp/data.csv' INTO TABLE map_data_type;
CREATE TABLE struct_data_type(
c_struct struct<c1:smallint,c2:varchar(30)>)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ','
COLLECTION ITEMS TERMINATED BY '&';
data.csv
file:
101&struct1
102&struct2
Load data into hive:
LOAD DATA LOCAL INPATH '/tmp/data.csv' INTO TABLE struct_data_type;
CREATE TABLE uniontype_data_type(
c_uniontype uniontype<int, double, array<string>)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ','
COLLECTION ITEMS TERMINATED BY '&';
data.csv
file:
0&10
1&10.23
2&arr1&arr2
Load data into hive:
LOAD DATA LOCAL INPATH '/tmp/data.csv' INTO TABLE uniontype_data_type;