Uploaded image for project: 'Calcite'
  1. Calcite
  2. CALCITE-1798

In JDBC adapter, generate dialect-specific SQL for FLOOR operator

VotersWatch issueWatchersLinkCloneUpdate Comment AuthorReplace String in CommentUpdate Comment VisibilityDelete Comments
    XMLWordPrintableJSON

    Details

    • Type: Bug
    • Status: Closed
    • Priority: Major
    • Resolution: Fixed
    • Affects Version/s: None
    • Fix Version/s: 1.13.0
    • Component/s: jdbc-adapter
    • Labels:

      Description

      The FLOOR operator (on dates) is currently broken for all jdbc dialects.
      The syntax allowed by the parser looks like: "FLOOR(datetime to timeUnit)".
      However no jdbc dialect (as far as I'm aware) actually name the function FLOOR:
      In postgres: DATE_TRUNC('year', my_datetime)
      In hsqldb: TRUNC ( my_datetime, 'YYYY' )
      In oracle: TRUNC(my_datetime, 'YEAR')
      In mysql: There's no direct equivalent in mysql (though it could be emulated with some nasty timestamp diffing)

      The other issue is that the timeUnits are sometimes also named differently by each dialect (e.g. 'YYYY' in hsqldb).

        Attachments

        Issue Links

          Activity

            People

            • Assignee:
              julianhyde Julian Hyde
              Reporter:
              chris-baynes Chris Baynes

              Dates

              • Created:
                Updated:
                Resolved:

                Issue deployment