Uploaded image for project: 'MariaDB Server'
  1. MariaDB Server
  2. MDEV-15340

Wrong result HOUR(case_expression_with_time_and_datetime)

Details

    • Bug
    • Status: Closed (View Workflow)
    • Major
    • Resolution: Fixed
    • 10.0(EOL), 10.1(EOL), 10.2(EOL), 10.3(EOL)
    • 10.3.5
    • Temporal Types
    • None

    Description

      SELECT
        COALESCE(TIME'800:00:00', NOW()) AS c,
        HOUR(COALESCE(TIME'800:00:00',NOW())) AS hc;
      

      +---------------------+------+
      | c                   | hc   |
      +---------------------+------+
      | 2018-03-22 08:00:00 |  800 |
      +---------------------+------+
      

      The result for hc is wrong. It returns HOURS() of the first argument of COALESCE() before its conversion to DATETIME. The expected result is to return hours after conversion, i,e. 8, like the hour part in the first column c.

      The same problem is repeatable with CASE and its abbreviations:

      SELECT
        CASE WHEN TRUE THEN TIME'800:00:00' ELSE NOW() END AS c,
        HOUR(CASE WHEN TRUE THEN TIME'800:00:00' ELSE NOW() END) AS hc;
      

      SELECT
        IFNULL(TIME'800:00:00', NOW()) AS c,
        HOUR(IFNULL(TIME'800:00:00', NOW())) AS hc;
      

      SELECT
        IF(TRUE,TIME'800:00:00', NOW()) AS c,
        HOUR(IF(TRUE,TIME'800:00:00', NOW())) AS hc;
      

      Attachments

        Issue Links

          Activity

            bar Alexander Barkov created issue -
            bar Alexander Barkov made changes -
            Field Original Value New Value
            Environment {code:sql}
            SELECT
              COALESCE(TIME'800:00:00', NOW()) AS c,
              HOUR(COALESCE(TIME'800:00:00',NOW())) AS hc;
            {code}
            {noformat}
            +---------------------+------+
            | c | hc |
            +---------------------+------+
            | 2018-03-22 08:00:00 | 800 |
            +---------------------+------+
            {noformat}
            The result for {{hc}} is wrong. It returns {{HOURS()}} of the first argument of {{COALESCE()}} before its conversion to {{DATETIME}}. The expected result is to return hours after conversion, i,e. {{8}}, like the hour part in the first column {{c}}.

            {code:sql}
            SELECT
              CASE WHEN TRUE THEN TIME'800:00:00' ELSE NOW() END AS c,
              HOUR(CASE WHEN TRUE THEN TIME'800:00:00' ELSE NOW() END) AS hc;
            {code}

            {code:sql}
            SELECT
              IFNULL(TIME'800:00:00', NOW()) AS c,
              HOUR(IFNULL(TIME'800:00:00', NOW())) AS hc;
            {code}

            {code:sql}
            SELECT
              IF(TRUE,TIME'800:00:00', NOW()) AS c,
              HOUR(IF(TRUE,TIME'800:00:00', NOW())) AS hc;
            {code}
            bar Alexander Barkov made changes -
            Description {code:sql}
            SELECT
              COALESCE(TIME'800:00:00', NOW()) AS c,
              HOUR(COALESCE(TIME'800:00:00',NOW())) AS hc;
            {code}
            {noformat}
            +---------------------+------+
            | c | hc |
            +---------------------+------+
            | 2018-03-22 08:00:00 | 800 |
            +---------------------+------+
            {noformat}
            The result for {{hc}} is wrong. It returns {{HOURS()}} of the first argument of {{COALESCE()}} before its conversion to {{DATETIME}}. The expected result is to return hours after conversion, i,e. {{8}}, like the hour part in the first column {{c}}.

            {code:sql}
            SELECT
              CASE WHEN TRUE THEN TIME'800:00:00' ELSE NOW() END AS c,
              HOUR(CASE WHEN TRUE THEN TIME'800:00:00' ELSE NOW() END) AS hc;
            {code}

            {code:sql}
            SELECT
              IFNULL(TIME'800:00:00', NOW()) AS c,
              HOUR(IFNULL(TIME'800:00:00', NOW())) AS hc;
            {code}

            {code:sql}
            SELECT
              IF(TRUE,TIME'800:00:00', NOW()) AS c,
              HOUR(IF(TRUE,TIME'800:00:00', NOW())) AS hc;
            {code}
            bar Alexander Barkov made changes -
            bar Alexander Barkov made changes -
            bar Alexander Barkov made changes -
            Description {code:sql}
            SELECT
              COALESCE(TIME'800:00:00', NOW()) AS c,
              HOUR(COALESCE(TIME'800:00:00',NOW())) AS hc;
            {code}
            {noformat}
            +---------------------+------+
            | c | hc |
            +---------------------+------+
            | 2018-03-22 08:00:00 | 800 |
            +---------------------+------+
            {noformat}
            The result for {{hc}} is wrong. It returns {{HOURS()}} of the first argument of {{COALESCE()}} before its conversion to {{DATETIME}}. The expected result is to return hours after conversion, i,e. {{8}}, like the hour part in the first column {{c}}.

            {code:sql}
            SELECT
              CASE WHEN TRUE THEN TIME'800:00:00' ELSE NOW() END AS c,
              HOUR(CASE WHEN TRUE THEN TIME'800:00:00' ELSE NOW() END) AS hc;
            {code}

            {code:sql}
            SELECT
              IFNULL(TIME'800:00:00', NOW()) AS c,
              HOUR(IFNULL(TIME'800:00:00', NOW())) AS hc;
            {code}

            {code:sql}
            SELECT
              IF(TRUE,TIME'800:00:00', NOW()) AS c,
              HOUR(IF(TRUE,TIME'800:00:00', NOW())) AS hc;
            {code}
            {code:sql}
            SELECT
              COALESCE(TIME'800:00:00', NOW()) AS c,
              HOUR(COALESCE(TIME'800:00:00',NOW())) AS hc;
            {code}
            {noformat}
            +---------------------+------+
            | c | hc |
            +---------------------+------+
            | 2018-03-22 08:00:00 | 800 |
            +---------------------+------+
            {noformat}
            The result for {{hc}} is wrong. It returns {{HOURS()}} of the first argument of {{COALESCE()}} before its conversion to {{DATETIME}}. The expected result is to return hours after conversion, i,e. {{8}}, like the hour part in the first column {{c}}.

            The same problem is repeatable with {{CASE}} and its abbreviations:
            {code:sql}
            SELECT
              CASE WHEN TRUE THEN TIME'800:00:00' ELSE NOW() END AS c,
              HOUR(CASE WHEN TRUE THEN TIME'800:00:00' ELSE NOW() END) AS hc;
            {code}

            {code:sql}
            SELECT
              IFNULL(TIME'800:00:00', NOW()) AS c,
              HOUR(IFNULL(TIME'800:00:00', NOW())) AS hc;
            {code}

            {code:sql}
            SELECT
              IF(TRUE,TIME'800:00:00', NOW()) AS c,
              HOUR(IF(TRUE,TIME'800:00:00', NOW())) AS hc;
            {code}
            bar Alexander Barkov made changes -
            issue.field.resolutiondate 2018-02-19 19:45:24.0 2018-02-19 19:45:24.099
            bar Alexander Barkov made changes -
            Fix Version/s 10.3.5 [ 22905 ]
            Fix Version/s 10.3 [ 22126 ]
            Resolution Fixed [ 1 ]
            Status Open [ 1 ] Closed [ 6 ]
            bar Alexander Barkov made changes -
            serg Sergei Golubchik made changes -
            Workflow MariaDB v3 [ 85623 ] MariaDB v4 [ 153816 ]

            People

              bar Alexander Barkov
              bar Alexander Barkov
              Votes:
              0 Vote for this issue
              Watchers:
              1 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved:

                Git Integration

                  Error rendering 'com.xiplink.jira.git.jira_git_plugin:git-issue-webpanel'. Please contact your Jira administrators.