Details

    • Technical task
    • Status: Closed (View Workflow)
    • Major
    • Resolution: Fixed
    • 10.3(EOL)
    • 10.3.3
    • Parser
    • None
    • 10.2.2-3, 10.2.2-1, 10.2.2-2, 10.2.2-4, 10.1.18

    Description

      In order to emulate Oracle's behavior in handling empty strings as NULL, we'll add a new sql_mode flag EMPTY_STRING_IS_NULL.
      When this flag is set, we will:

      • translate Item_string created in the parser to Item_null
      • translate binding an empty string as prepared statement parameters to binding NULL

      Note, more NULL handling flags will be added later under terms of separate patch:

      • translating empty strings in function return values to NULL
      • handling empty strings as equal to NULL in comparison operators

      This task is only about literals and PS parameters.

      The new flag will be disabled by default.
      The new flag will NOT be a part of sql_mode=ORACLE.

      In order to activate this behavior, one will have to do:

      SET sql_mode='ORACLE,EMPTY_STRING_IS_NULL';
      

      Attachments

        Issue Links

          Activity

            bar Alexander Barkov created issue -
            bar Alexander Barkov made changes -
            Field Original Value New Value
            Description In order to emulate Oracle's behavior in handling empty strings as NULL, we'll add a new sql_mode flag {{EMPTY_STRING_IS_NULL}}.
            When this flag is set, we will:
            - translate Item_string created in the parser to Item_null
            - translate binding an empty string as prepared statement parameters to binding NULL

            Note, more {{NULL}} handling flags will be added later under terms of separate patch:
            - translating empty strings in function return values to NULL
            - handling empty strings as equal to NULL in comparison operators

            This task is only about literals and PS parameters.
            In order to emulate Oracle's behavior in handling empty strings as NULL, we'll add a new sql_mode flag {{EMPTY_STRING_IS_NULL}}.
            When this flag is set, we will:
            - translate Item_string created in the parser to Item_null
            - translate binding an empty string as prepared statement parameters to binding NULL

            Note, more {{NULL}} handling flags will be added later under terms of separate patch:
            - translating empty strings in function return values to NULL
            - handling empty strings as equal to NULL in comparison operators

            This task is only about literals and PS parameters.

            The new flag will be disabled by default.
            The new flag will NOT be a part of sql_mode=ORACLE.

            In order to activate this behavior, one will have to do:
            {code:sql}
            SET sql_mode='ORACLE,EMPTY_STRING_IS_NULL';
            {code}
            bar Alexander Barkov made changes -
            Status Open [ 1 ] In Progress [ 3 ]
            bar Alexander Barkov made changes -
            Fix Version/s 10.3.3 [ 22644 ]
            Fix Version/s 10.3 [ 22126 ]
            Resolution Fixed [ 1 ]
            Status In Progress [ 3 ] Closed [ 6 ]
            alvinr Alvin Richards (Inactive) made changes -
            Parent MDEV-10764 [ 57940 ] MDEV-10142 [ 56873 ]
            alice Alice Sherepa made changes -
            bar Alexander Barkov made changes -
            serg Sergei Golubchik made changes -
            Workflow MariaDB v3 [ 82942 ] MariaDB v4 [ 152946 ]
            bar Alexander Barkov made changes -

            People

              bar Alexander Barkov
              bar Alexander Barkov
              Votes:
              0 Vote for this issue
              Watchers:
              5 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.