SNOW-2119489: Add support for interval types in json format #2336
+133
−68
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Please answer these questions before submitting your pull requests. Thanks!
What GitHub issue is this PR addressing? Make sure that there is an accompanying issue to your PR.
Fixes SNOW-2119489
Fill out the following pre-review checklist:
Please describe how your code solves the related issue.
This PR adds support for INTERVAL YEAR MONTH and INTERVAL DAY TIME to the python connector in JSON format.
Implementation details:
For year-month interval we receive number of months as integer (represented as string) from server. Python timedelta only supports days, seconds and microseconds so this is mapped to ANSI formatted interval string. In numpy it is mapped to numpy.timedelta64.
For day-time interval we receive number of nanoseconds as integer (represented as string). We convert this to timedelta and numpy.timedelta64.