How to check whether any particular partition exist or not in HIVE
- desc mytable partition (...)
- show table extended like mytable partition (...)
Execute from shell using hive -e '...'
Demo
create table mytable (i int)
partitioned by (year int,month tinyint,day tinyint)
;
insert into mytable partition(year,month,day) values (1,2017,3,29)
;
hive> desc mytable partition (year=2017,month=3,day=29);
OK
i int
year int
month tinyint
day tinyint
# Partition Information
# col_name data_type comment
year int
month tinyint
day tinyint
hive> desc mytable partition (year=2017,month=4,day=1);
FAILED: SemanticException [Error 10006]: Partition not found {year=2017, month=4, day=1}
hive> show table extended like mytable partition (year=2017,month=3,day=29);
OK
tableName:mytable
owner:cloudera
location:hdfs://quickstart.cloudera:8020/user/hive/warehouse/mytable/year=2017/month=3/day=29
inputformat:org.apache.hadoop.mapred.TextInputFormat
outputformat:org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat
columns:struct columns { i32 i}
partitioned:true
partitionColumns:struct partition_columns { i32 year, byte month, byte day}
totalNumberFiles:1
totalFileSize:2
maxFileSize:2
minFileSize:2
lastAccessTime:1490770378864
lastUpdateTime:1490770379748
hive> show table extended like mytable partition (year=2017,month=4,day=1);
FAILED: SemanticException [Error 10006]: Partition not found {year=2017, month=4, day=1}