Prasanth J created HIVE-5240:
--------------------------------
Summary: Column statistics on a partitioned column should fail
early with proper error message
Key: HIVE-5240
URL: https://issues.apache.org/jira/browse/HIVE-5240
Project: Hive
Issue Type: Bug
Components: Statistics
Affects Versions: 0.12.0
Reporter: Prasanth J
Assignee: Prasanth J
Fix For: 0.12.0
Attachments: HIVE-5240.txt
When computing column statistics on a partitioned table, if one of the columns
equals the partitioned column then IndexOutOfBoundsException is thrown.
Following analyze query throws IndexOutOfBoundsException during semantic
analysis phase
{code}hive> analyze table qlog_1m_part partition(year=5) compute statistics for
columns year,month,week,type;
FAILED: IndexOutOfBoundsException Index: 1, Size: 0{code}
If the partitioned column is specified at last like below then the same
exception is thrown at runtime
{code}hive> analyze table qlog_1m_part partition(year=5) compute statistics for
columns month,week,type,year;
Hadoop job information for null: number of mappers: 0; number of reducers: 0
2013-09-06 18:05:06,587 null map = 0%, reduce = 100%
Ended Job = job_local861862820_0001
Execution completed successfully
Mapred Local Task Succeeded . Convert the Join into MapJoin
java.lang.IndexOutOfBoundsException: Index: 3, Size: 3
at java.util.LinkedList.entry(LinkedList.java:365)
at java.util.LinkedList.get(LinkedList.java:315)
at
org.apache.hadoop.hive.ql.exec.ColumnStatsTask.constructColumnStatsFromPackedRow(ColumnStatsTask.java:262)
at
org.apache.hadoop.hive.ql.exec.ColumnStatsTask.persistPartitionStats(ColumnStatsTask.java:302)
at
org.apache.hadoop.hive.ql.exec.ColumnStatsTask.execute(ColumnStatsTask.java:345)
at org.apache.hadoop.hive.ql.exec.Task.executeTask(Task.java:151)
at
org.apache.hadoop.hive.ql.exec.TaskRunner.runSequential(TaskRunner.java:65)
at org.apache.hadoop.hive.ql.Driver.launchTask(Driver.java:1407)
at org.apache.hadoop.hive.ql.Driver.execute(Driver.java:1187)
at org.apache.hadoop.hive.ql.Driver.runInternal(Driver.java:1017)
at org.apache.hadoop.hive.ql.Driver.run(Driver.java:885)
at
org.apache.hadoop.hive.cli.CliDriver.processLocalCmd(CliDriver.java:259)
at org.apache.hadoop.hive.cli.CliDriver.processCmd(CliDriver.java:216)
at org.apache.hadoop.hive.cli.CliDriver.processLine(CliDriver.java:413)
at
org.apache.hadoop.hive.cli.CliDriver.executeDriver(CliDriver.java:781)
at org.apache.hadoop.hive.cli.CliDriver.run(CliDriver.java:675)
at org.apache.hadoop.hive.cli.CliDriver.main(CliDriver.java:614)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.apache.hadoop.util.RunJar.main(RunJar.java:160)
{code}
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira