[ 
https://issues.apache.org/jira/browse/SPARK-57816?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Max Gekk updated SPARK-57816:
-----------------------------
    Shepherd: Max Gekk

> Support nanosecond-precision timestamps in date_format, to_char and to_varchar
> ------------------------------------------------------------------------------
>
>                 Key: SPARK-57816
>                 URL: https://issues.apache.org/jira/browse/SPARK-57816
>             Project: Spark
>          Issue Type: Sub-task
>          Components: SQL
>    Affects Versions: 4.3.0
>            Reporter: Max Gekk
>            Priority: Major
>
> This sub-task is part of the umbrella SPARK-56822 (timestamps with nanosecond 
> precision).
> h2. Problem
> {{DateFormatClass}} (datetimeExpressions.scala ~L1235-1252) has {{inputTypes 
> = Seq(TimestampType, AnyTimeType)}} (or string) and formats 
> {{timestamp.asInstanceOf[Long]}} micros; {{ToCharacterBuilder}} 
> (numberFormatExpressions.scala ~L255-256) routes any {{DatetimeType}} (which 
> includes the nanosecond types) into {{DateFormatClass}}. Nanosecond input is 
> therefore narrowed to microseconds and the sub-microsecond digits never reach 
> the formatter.
> h2. Goal
> Format nanosecond timestamps at full precision, honoring the pattern's 
> fractional-second placeholders up to 9 digits, with correct NTZ 
> (zone-independent) vs LTZ (session-zone) rendering.
> h2. Scope
> Accept {{AnyTimestampNanoType}} in {{DateFormatClass.inputTypes}}; add a 
> {{TimestampNanosVal}} formatting path reusing the nanosecond-aware 
> {{TimestampFormatter}} ({{formatNanos}} / {{formatWithoutTimeZoneNanos}}); 
> wire {{to_char}} / {{to_varchar}} accordingly.
> h2. Acceptance criteria
> * {{date_format(ts_nanos, "...SSSSSSSSS")}} and {{to_char(ts_nanos, ...)}} 
> render up to nanosecond digits; NTZ vs LTZ zone behavior matches the 
> microsecond types.
> h2. Testing
> {{DateFunctionsSuite}} / {{DateExpressionsSuite}}; nanos golden files.
> h2. Dependencies
> None - independent (uses the resolved nanosecond-aware formatter, 
> SPARK-57162).



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to