Skip to content
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

[SPARK-51454][SQL] Support cast from time to string #50224

Closed
wants to merge 2 commits into from

Conversation

MaxGekk
Copy link
Member

@MaxGekk MaxGekk commented Mar 10, 2025

What changes were proposed in this pull request?

In the PR, I propose to support casting of TIME to STRING using the fraction formatter which formats times according to the pattern HH:mm:ss.[..fff..]. The pattern [..fff..] is a fraction of second up to microsecond resolution. The formatter does not output trailing zeros in the fraction. Apparently the ToPrettyString expression and .show() support such casting too.

Also the PR adds the support of TIME literals created from java.time.LocalTime (used it tests).

Why are the changes needed?

To output time values in user friendly format. Before the changes, show prints internal representation of time values:

scala> Seq(LocalTime.parse("17:18:19")).toDS.show()
+-----------+
|      value|
+-----------+
|62299000000|
+-----------+

Does this PR introduce any user-facing change?

Yes. After the changes, the command above outputs time values in new format:

scala> Seq(LocalTime.parse("17:18:19")).toDS.show()
+--------+
|   value|
+--------+
|17:18:19|
+--------+

How was this patch tested?

By running new tests:

$ build/sbt "test:testOnly *ToPrettyStringSuite"
$ build/sbt "test:testOnly *CastWithAnsiOnSuite"

Was this patch authored or co-authored using generative AI tooling?

No.

@github-actions github-actions bot added the SQL label Mar 10, 2025
@MaxGekk MaxGekk changed the title [WIP][SQL] Support cast from time to string [WIP][SPARK-51454][SQL] Support cast from time to string Mar 10, 2025
@MaxGekk MaxGekk marked this pull request as ready for review March 10, 2025 15:51
@MaxGekk MaxGekk changed the title [WIP][SPARK-51454][SQL] Support cast from time to string [SPARK-51454][SQL] Support cast from time to string Mar 10, 2025
Copy link
Member

@dongjoon-hyun dongjoon-hyun left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

+1, LGTM. Thank you, @MaxGekk .
Merged to master for Apache Spark 4.1.0.

@LuciferYang
Copy link
Contributor

late LGTM

anoopj pushed a commit to anoopj/spark that referenced this pull request Mar 15, 2025
### What changes were proposed in this pull request?
In the PR, I propose to support casting of TIME to STRING using the fraction formatter which formats times according to the pattern `HH:mm:ss.[..fff..]`. The pattern `[..fff..]` is a fraction of second up to microsecond resolution. The formatter does not output trailing zeros in the fraction. Apparently the `ToPrettyString` expression and `.show()` support such casting too.

Also the PR adds the support of TIME literals created from `java.time.LocalTime` (used it tests).

### Why are the changes needed?
To output time values in user friendly format. Before the changes, show prints internal representation of time values:
```scala
scala> Seq(LocalTime.parse("17:18:19")).toDS.show()
+-----------+
|      value|
+-----------+
|62299000000|
+-----------+
```

### Does this PR introduce _any_ user-facing change?
Yes. After the changes, the command above outputs time values in new format:
```scala
scala> Seq(LocalTime.parse("17:18:19")).toDS.show()
+--------+
|   value|
+--------+
|17:18:19|
+--------+
```

### How was this patch tested?
By running new tests:
```
$ build/sbt "test:testOnly *ToPrettyStringSuite"
$ build/sbt "test:testOnly *CastWithAnsiOnSuite"
```

### Was this patch authored or co-authored using generative AI tooling?
No.

Closes apache#50224 from MaxGekk/time-cast-to-string.

Authored-by: Max Gekk <[email protected]>
Signed-off-by: Dongjoon Hyun <[email protected]>
@the-sakthi
Copy link
Member

Missed out on this PR. Late LGTM!

kazemaksOG pushed a commit to kazemaksOG/spark-custom-scheduler that referenced this pull request Mar 27, 2025
### What changes were proposed in this pull request?
In the PR, I propose to support casting of TIME to STRING using the fraction formatter which formats times according to the pattern `HH:mm:ss.[..fff..]`. The pattern `[..fff..]` is a fraction of second up to microsecond resolution. The formatter does not output trailing zeros in the fraction. Apparently the `ToPrettyString` expression and `.show()` support such casting too.

Also the PR adds the support of TIME literals created from `java.time.LocalTime` (used it tests).

### Why are the changes needed?
To output time values in user friendly format. Before the changes, show prints internal representation of time values:
```scala
scala> Seq(LocalTime.parse("17:18:19")).toDS.show()
+-----------+
|      value|
+-----------+
|62299000000|
+-----------+
```

### Does this PR introduce _any_ user-facing change?
Yes. After the changes, the command above outputs time values in new format:
```scala
scala> Seq(LocalTime.parse("17:18:19")).toDS.show()
+--------+
|   value|
+--------+
|17:18:19|
+--------+
```

### How was this patch tested?
By running new tests:
```
$ build/sbt "test:testOnly *ToPrettyStringSuite"
$ build/sbt "test:testOnly *CastWithAnsiOnSuite"
```

### Was this patch authored or co-authored using generative AI tooling?
No.

Closes apache#50224 from MaxGekk/time-cast-to-string.

Authored-by: Max Gekk <[email protected]>
Signed-off-by: Dongjoon Hyun <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants