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

Wrong number of decimal digits in certain UNION/Subqery constellation

Details

    Description

      UNION of an UNSIGNED result, and a NULL result from a subquery, leads to wrong number of decimals. See the following two one liner test queries, which were run with `mysql --column-type-info`. This only started with 10.3.

      MariaDB [test]> select CAST(1 as unsigned) union all select NULL;
      Field   1:  `CAST(1 as unsigned)`
      Catalog:    `def`
      Database:   ``
      Table:      ``
      Org_table:  ``
      Type:       NEWDECIMAL
      Collation:  binary (63)
      Length:     2
      Max_length: 1
      Decimals:   0
      Flags:      BINARY NUM 
       
       
      +---------------------+
      | CAST(1 as unsigned) |
      +---------------------+
      |                   1 |
      |                NULL |
      +---------------------+
      2 rows in set (0.000 sec)
       
      MariaDB [test]> select CAST(1 as unsigned) union all select * from (select NULL) t;
      Field   1:  `CAST(1 as unsigned)`
      Catalog:    `def`
      Database:   ``
      Table:      ``
      Org_table:  ``
      Type:       NEWDECIMAL
      Collation:  binary (63)
      Length:     42
      Max_length: 40
      Decimals:   39
      Flags:      BINARY NUM 
       
       
      +------------------------------------------+
      | CAST(1 as unsigned)                      |
      +------------------------------------------+
      | 1.00000000000000000000000000000000000000 |
      |                                     NULL |
      +------------------------------------------+
      2 rows in set (0.000 sec)
      
      

      Attachments

        Issue Links

          Activity

            hholzgra Hartmut Holzgraefe created issue -
            hholzgra Hartmut Holzgraefe made changes -
            Field Original Value New Value
            Component/s Data types [ 13906 ]
            alice Alice Sherepa made changes -
            alice Alice Sherepa added a comment - it was changed after https://github.com/MariaDB/server/commit/705fc43eaa ( MDEV-12775 )
            julien.fritsch Julien Fritsch made changes -
            Assignee Dmitry Shulga [ JIRAUSER47315 ]
            sanja Oleksandr Byelkin made changes -
            Assignee Dmitry Shulga [ JIRAUSER47315 ] Rucha Deodhar [ rucha174 ]
            rucha174 Rucha Deodhar made changes -
            Fix Version/s 10.3.28 [ 25111 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 10.3 [ 22126 ]
            Fix Version/s 10.4 [ 22408 ]
            Fix Version/s 10.5 [ 23123 ]
            Fix Version/s 10.3.28 [ 25111 ]
            rucha174 Rucha Deodhar made changes -
            Status Open [ 1 ] In Progress [ 3 ]
            rucha174 Rucha Deodhar added a comment - Patch: https://github.com/MariaDB/server/commit/f2392c72cb354224db36066f62dacb228c70d7a0
            rucha174 Rucha Deodhar made changes -
            Assignee Rucha Deodhar [ rucha174 ] Alexander Barkov [ bar ]
            Status In Progress [ 3 ] In Review [ 10002 ]

            The patch https://github.com/MariaDB/server/commit/f2392c72cb354224db36066f62dacb228c70d7a0 looks OK to me.

            I suggest to change tests though:

            instead of calling "mysql" command line client, please execute these queries directly in *.test file using --enable_metadata and --disable_metadata around queries.

            This is the usual way how we check result set metadata.

            bar Alexander Barkov added a comment - The patch https://github.com/MariaDB/server/commit/f2392c72cb354224db36066f62dacb228c70d7a0 looks OK to me. I suggest to change tests though: instead of calling "mysql" command line client, please execute these queries directly in *.test file using --enable_metadata and --disable_metadata around queries. This is the usual way how we check result set metadata.
            bar Alexander Barkov made changes -
            Status In Review [ 10002 ] Stalled [ 10000 ]
            bar Alexander Barkov made changes -
            Assignee Alexander Barkov [ bar ] Rucha Deodhar [ rucha174 ]
            rucha174 Rucha Deodhar made changes -
            Status Stalled [ 10000 ] In Progress [ 3 ]
            rucha174 Rucha Deodhar added a comment - Patch after latest changes: https://github.com/MariaDB/server/commit/c597d9234c0072a77122f2810212877f1a532d3d
            rucha174 Rucha Deodhar made changes -
            Assignee Rucha Deodhar [ rucha174 ] Alexander Barkov [ bar ]
            Status In Progress [ 3 ] In Review [ 10002 ]

            Ok to push. Thanks!

            bar Alexander Barkov added a comment - Ok to push. Thanks!
            bar Alexander Barkov made changes -
            Status In Review [ 10002 ] Stalled [ 10000 ]
            rucha174 Rucha Deodhar made changes -
            Fix Version/s 10.3.28 [ 25111 ]
            Fix Version/s 10.4.18 [ 25110 ]
            Fix Version/s 10.5.9 [ 25109 ]
            Fix Version/s 10.3 [ 22126 ]
            Fix Version/s 10.4 [ 22408 ]
            Fix Version/s 10.5 [ 23123 ]
            Resolution Fixed [ 1 ]
            Status Stalled [ 10000 ] Closed [ 6 ]
            serg Sergei Golubchik made changes -
            Workflow MariaDB v3 [ 116769 ] MariaDB v4 [ 158678 ]
            mariadb-jira-automation Jira Automation (IT) made changes -
            Zendesk Related Tickets 141151

            People

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