[jira] [Updated] (HIVE-22224) Support Parquet-Avro Timestamp Type
[ https://issues.apache.org/jira/browse/HIVE-4?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Alan Gates updated HIVE-4: -- Fix Version/s: (was: 2.3.7) > Support Parquet-Avro Timestamp Type > --- > > Key: HIVE-4 > URL: https://issues.apache.org/jira/browse/HIVE-4 > Project: Hive > Issue Type: Bug > Components: Database/Schema >Affects Versions: 2.3.5, 2.3.6 >Reporter: cdmikechen >Assignee: cdmikechen >Priority: Major > Labels: parquet, pull-request-available > Time Spent: 10m > Remaining Estimate: 0h > > When user create an external table and import a parquet-avro data with 1.8.2 > version which supported logical_type in Hive2.3 or before version, Hive can > not read timestamp type column data correctly. > Hive will read it as LongWritable which it actually stores as > long(logical_type=timestamp-millis).So we may add some codes in > org.apache.hadoop.hive.serde2.objectinspector.primitive.WritableTimestampObjectInspector.java > to let Hive cast long type to timestamp type. > Some code like below: > > public Timestamp getPrimitiveJavaObject(Object o) { > if (o instanceof LongWritable) { > return new Timestamp(((LongWritable) o).get()); > } > return o == null ? null : ((TimestampWritable) o).getTimestamp(); > } > -- This message was sent by Atlassian Jira (v8.3.4#803005)
[jira] [Updated] (HIVE-22224) Support Parquet-Avro Timestamp Type
[ https://issues.apache.org/jira/browse/HIVE-4?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] cdmikechen updated HIVE-4: -- Status: Patch Available (was: In Progress) > Support Parquet-Avro Timestamp Type > --- > > Key: HIVE-4 > URL: https://issues.apache.org/jira/browse/HIVE-4 > Project: Hive > Issue Type: Bug > Components: Database/Schema >Affects Versions: 2.3.6, 2.3.5 >Reporter: cdmikechen >Assignee: cdmikechen >Priority: Major > Labels: parquet, pull-request-available > Fix For: 2.3.7 > > Time Spent: 10m > Remaining Estimate: 0h > > When user create an external table and import a parquet-avro data with 1.8.2 > version which supported logical_type in Hive2.3 or before version, Hive can > not read timestamp type column data correctly. > Hive will read it as LongWritable which it actually stores as > long(logical_type=timestamp-millis).So we may add some codes in > org.apache.hadoop.hive.serde2.objectinspector.primitive.WritableTimestampObjectInspector.java > to let Hive cast long type to timestamp type. > Some code like below: > > public Timestamp getPrimitiveJavaObject(Object o) { > if (o instanceof LongWritable) { > return new Timestamp(((LongWritable) o).get()); > } > return o == null ? null : ((TimestampWritable) o).getTimestamp(); > } > -- This message was sent by Atlassian Jira (v8.3.4#803005)
[jira] [Updated] (HIVE-22224) Support Parquet-Avro Timestamp Type
[ https://issues.apache.org/jira/browse/HIVE-4?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] ASF GitHub Bot updated HIVE-4: -- Labels: parquet pull-request-available (was: parquet) > Support Parquet-Avro Timestamp Type > --- > > Key: HIVE-4 > URL: https://issues.apache.org/jira/browse/HIVE-4 > Project: Hive > Issue Type: Bug > Components: Database/Schema >Affects Versions: 2.3.5, 2.3.6 >Reporter: cdmikechen >Assignee: cdmikechen >Priority: Major > Labels: parquet, pull-request-available > Fix For: 2.3.7 > > > When user create an external table and import a parquet-avro data with 1.8.2 > version which supported logical_type in Hive2.3 or before version, Hive can > not read timestamp type column data correctly. > Hive will read it as LongWritable which it actually stores as > long(logical_type=timestamp-millis).So we may add some codes in > org.apache.hadoop.hive.serde2.objectinspector.primitive.WritableTimestampObjectInspector.java > to let Hive cast long type to timestamp type. > Some code like below: > > public Timestamp getPrimitiveJavaObject(Object o) { > if (o instanceof LongWritable) { > return new Timestamp(((LongWritable) o).get()); > } > return o == null ? null : ((TimestampWritable) o).getTimestamp(); > } > -- This message was sent by Atlassian Jira (v8.3.4#803005)
[jira] [Updated] (HIVE-22224) Support Parquet-Avro Timestamp Type
[ https://issues.apache.org/jira/browse/HIVE-4?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] cdmikechen updated HIVE-4: -- Labels: parquet (was: ) > Support Parquet-Avro Timestamp Type > --- > > Key: HIVE-4 > URL: https://issues.apache.org/jira/browse/HIVE-4 > Project: Hive > Issue Type: Bug > Components: Database/Schema >Affects Versions: 2.3.5, 2.3.6 >Reporter: cdmikechen >Priority: Major > Labels: parquet > Fix For: 2.3.7 > > > When user create an external table and import a parquet-avro data with 1.8.2 > version which supported logical_type in Hive2.3 or before version, Hive can > not read timestamp type column data correctly. > Hive will read it as LongWritable which it actually stores as > long(logical_type=timestamp-millis).So we may add some codes in > org.apache.hadoop.hive.serde2.objectinspector.primitive.WritableTimestampObjectInspector.java > to let Hive cast long type to timestamp type. > Some code like below: > > public Timestamp getPrimitiveJavaObject(Object o) { > if (o instanceof LongWritable) { > return new Timestamp(((LongWritable) o).get()); > } > return o == null ? null : ((TimestampWritable) o).getTimestamp(); > } > -- This message was sent by Atlassian Jira (v8.3.4#803005)
[jira] [Updated] (HIVE-22224) Support Parquet-Avro Timestamp Type
[ https://issues.apache.org/jira/browse/HIVE-4?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] cdmikechen updated HIVE-4: -- Description: When user create an external table and import a parquet-avro data with 1.8.2 version which supported logical_type in Hive2.3 or before version, Hive can not read timestamp type column data correctly. Hive will read it as LongWritable which it actually stores as long(logical_type=timestamp-millis).So we may add some codes in org.apache.hadoop.hive.serde2.objectinspector.primitive.WritableTimestampObjectInspector.java to let Hive cast long type to timestamp type. Some code like below: public Timestamp getPrimitiveJavaObject(Object o) { if (o instanceof LongWritable) { return new Timestamp(((LongWritable) o).get()); } return o == null ? null : ((TimestampWritable) o).getTimestamp(); } was: When user create an external table and import a parquet-avro data with 1.8.2 version which supported logical_type in Hive2.3 or before version, Hive can not read timestamp type column data correctly. Hive will read it as LongWritable which it actually stores as long(logical_type=timestamp-millis).So we may add some codes in org.apache.hadoop.hive.serde2.objectinspector.primitive.WritableTimestampObjectInspector.java to let Hive cast long type to timestamp type. Some code like below: public Timestamp getPrimitiveJavaObject(Object o) { if (o instanceof LongWritable) { return new Timestamp(((LongWritable) o).get()); } return o == null ? null : ((TimestampWritable) o).getTimestamp(); } > Support Parquet-Avro Timestamp Type > --- > > Key: HIVE-4 > URL: https://issues.apache.org/jira/browse/HIVE-4 > Project: Hive > Issue Type: Bug > Components: Database/Schema >Affects Versions: 2.3.5, 2.3.6 >Reporter: cdmikechen >Priority: Major > Labels: parquet > Fix For: 2.3.7 > > > When user create an external table and import a parquet-avro data with 1.8.2 > version which supported logical_type in Hive2.3 or before version, Hive can > not read timestamp type column data correctly. > Hive will read it as LongWritable which it actually stores as > long(logical_type=timestamp-millis).So we may add some codes in > org.apache.hadoop.hive.serde2.objectinspector.primitive.WritableTimestampObjectInspector.java > to let Hive cast long type to timestamp type. > Some code like below: > > public Timestamp getPrimitiveJavaObject(Object o) { > if (o instanceof LongWritable) { > return new Timestamp(((LongWritable) o).get()); > } > return o == null ? null : ((TimestampWritable) o).getTimestamp(); > } > -- This message was sent by Atlassian Jira (v8.3.4#803005)