-
Notifications
You must be signed in to change notification settings - Fork 392
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[#4743]fix(trino-connector): Fix the default precision of time and timestamp in the Iceberg catalog. #4893
Conversation
Does this need to be backported to branch-0.6? |
...ctor/src/main/java/org/apache/gravitino/trino/connector/util/GeneralDataTypeTransformer.java
Show resolved
Hide resolved
@@ -20,6 +20,9 @@ | |||
package org.apache.gravitino.trino.connector.catalog.iceberg; | |||
|
|||
import io.trino.spi.TrinoException; | |||
import io.trino.spi.type.TimeType; | |||
import io.trino.spi.type.TimestampType; | |||
import io.trino.spi.type.TimestampWithTimeZoneType; | |||
import io.trino.spi.type.VarbinaryType; | |||
import io.trino.spi.type.VarcharType; | |||
import org.apache.gravitino.rel.types.Type; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
seems you shoud add corresponding logic to convert MICROS time to Iceberg time, and forbidden other time precision.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Trino iceberg connector can automatically convert other time precision to microsecond
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what will happen if the user creates an Iceberg table with timestamp(3)
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It automatically converts to timestamp(6)
, The behavior is the same as in the Trino Iceberg catalog.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
according to the code https://github.com/trinodb/trino/blob/457/plugin/trino-iceberg/src/main/java/io/trino/plugin/iceberg/TypeConverter.java#L148-L177, it will throw an exception in origin Trino Iceberg catalog, Yes?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
so I don't think it's the right behavior to convert timestamp(3)
to timestamp(6)
in Gravitino Iceberg connector, it conflict with original behavior.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Trino Iceberg connector can automatically converts timestamp and timestamp(n) to timestamp(6),
The Gravitino connector Iceberg catalog's behavior is the same as Trino Iceberg connector
Yes |
LGTM |
…mestamp in the Iceberg catalog. (#4893) ### What changes were proposed in this pull request? Fix the default precision of time and timestamp in the Iceberg catalog. It causes Trino to be unable to read Iceberg tables with data of time and timestamp ### Why are the changes needed? Fix: #4743 ### Does this PR introduce _any_ user-facing change? NO ### How was this patch tested? New UT, IT
What changes were proposed in this pull request?
Fix the default precision of time and timestamp in the Iceberg catalog.
It causes Trino to be unable to read Iceberg tables with data of time and timestamp
Why are the changes needed?
Fix: #4743
Does this PR introduce any user-facing change?
NO
How was this patch tested?
New UT, IT