Details
-
Bug
-
Status: Closed
-
Major
-
Resolution: Fixed
-
1.2.1, 4.0.0
-
Tested on versions `1.2.1` and the latest 4.0.0-SNAPSHOT
Description
The issue reproduces only for a date column for a partitioned table. It reproduces only if the date column has all the values set to null, and if the partition is not empty.
Here is a quick reproducer:
CREATE TABLE dummy_table ( c_date DATE, c_bigint BIGINT ) PARTITIONED BY (ds STRING); INSERT OVERWRITE TABLE dummy_table PARTITION (ds='2018-01-01') SELECT CAST(null AS DATE), CAST(null AS BIGINT) FROM <any non empty table>; ANALYZE TABLE dummy_table COMPUTE STATISTICS FOR COLUMNS; DESCRIBE FORMATTED dummy_table.c_bigint PARTITION (ds='2018-01-01'); DESCRIBE FORMATTED dummy_table.c_date PARTITION (ds='2018-01-01');
The first `DESCRIBE FORMATTED` statement succeeds, when the second fails with an `NPE`
It happens because the null check is missing when converting Object from the ObjectStore to the Thrift object. The null check is missing only in the date statistics conversion for the partitioned table.