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

ANY_VALUE function as a workaround for ONLY_FULL_GROUP_BY mode, SQL-2023-T626, and compatibility with MySQL 5.7

Details

    Description

      Since version 5.7.5 Mysql has the "ONLY_FULL_GROUP_BY" flag by default enabled and I am trying to make some software that I maintain to be compatible with that.

      The most clean way to achieve that is with the ANY_VALUE() function. If you give a query like

      SELECT ANY_VALUE(var1), ANY_VALUE(var2), color FROM mybase GROUP BY color

      Mysql will not complain that var1 and var2 are not determined.

      Unfortunately when I use this under MariaDb I get the following error:

      MySQL error 1728: Cannot load from mysql.proc. The table is probably corrupted

      As soon as you remove the ANY_VALUE the error disappears - so it must be related to this function.


      See also MDEV-30766 where this function is needed for the query to return correct results

      Attachments

        Issue Links

          Activity

            musicpanda Wim Roffel created issue -
            elenst Elena Stepanova made changes -
            Field Original Value New Value
            Labels need_feedback
            elenst Elena Stepanova made changes -
            Labels need_feedback
            elenst Elena Stepanova made changes -
            Labels need_feedback
            elenst Elena Stepanova made changes -
            Labels need_feedback
            elenst Elena Stepanova made changes -
            Summary ANY_VALUE gives error 1728: table corrupted ANY_VALUE function as a workaround for ONLY_FULL_GROUP_BY mode and compatibility with MySQL 5.7
            elenst Elena Stepanova made changes -
            Affects Version/s 10.1.16 [ 22019 ]
            Environment Windows 10
            Issue Type Bug [ 1 ] Task [ 3 ]
            elenst Elena Stepanova made changes -
            Component/s Data Manipulation - Subquery [ 10107 ]
            elenst Elena Stepanova made changes -
            Priority Major [ 3 ] Minor [ 4 ]
            elenst Elena Stepanova made changes -
            Fix Version/s 10.2 [ 14601 ]
            elenst Elena Stepanova made changes -
            Fix Version/s 10.3 [ 22126 ]
            Fix Version/s 10.2 [ 14601 ]
            elenst Elena Stepanova made changes -
            elenst Elena Stepanova made changes -
            Priority Minor [ 4 ] Major [ 3 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 10.3 [ 22126 ]
            greenman Ian Gilfillan made changes -
            Labels Compatibility compat57
            serg Sergei Golubchik made changes -
            Workflow MariaDB v3 [ 76479 ] MariaDB v4 [ 130509 ]
            greenman Ian Gilfillan made changes -
            Labels Compatibility compat57 Compatibility compat57 compat80
            monty Michael Widenius made changes -
            serg Sergei Golubchik made changes -
            serg Sergei Golubchik made changes -
            Description Since version 5.7.5 Mysql has the "ONLY_FULL_GROUP_BY" flag by default enabled and I am trying to make some software that I maintain to be compatible with that.

            The most clean way to achieve that is with the ANY_VALUE() function. If you give a query like

            *_SELECT ANY_VALUE(var1), ANY_VALUE(var2), color FROM mybase GROUP BY color_*

            Mysql will not complain that var1 and var2 are not determined.

            Unfortunately when I use this under MariaDb I get the following error:

            *{color:#14892c}MySQL error 1728: Cannot load from mysql.proc. The table is probably corrupted{color}*

            As soon as you remove the ANY_VALUE the error disappears - so it must be related to this function.
            Since version 5.7.5 Mysql has the "ONLY_FULL_GROUP_BY" flag by default enabled and I am trying to make some software that I maintain to be compatible with that.

            The most clean way to achieve that is with the ANY_VALUE() function. If you give a query like

            *_SELECT ANY_VALUE(var1), ANY_VALUE(var2), color FROM mybase GROUP BY color_*

            Mysql will not complain that var1 and var2 are not determined.

            Unfortunately when I use this under MariaDb I get the following error:

            *{color:#14892c}MySQL error 1728: Cannot load from mysql.proc. The table is probably corrupted{color}*

            As soon as you remove the ANY_VALUE the error disappears - so it must be related to this function.

            ----

            See also MDEV-30766 where this function is needed for the query to return correct results
            serg Sergei Golubchik made changes -
            Fix Version/s 11.2 [ 28603 ]
            serg Sergei Golubchik made changes -
            Assignee Sergei Petrunia [ psergey ]
            danblack Daniel Black made changes -
            Labels Compatibility compat57 compat80 Compatibility compat57 compat80 sql2023
            ralf.gebhardt Ralf Gebhardt made changes -
            Fix Version/s 11.3 [ 28565 ]
            Fix Version/s 11.2 [ 28603 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 11.4 [ 29301 ]
            Fix Version/s 11.3 [ 28565 ]
            danblack Daniel Black made changes -
            danblack Daniel Black made changes -
            Summary ANY_VALUE function as a workaround for ONLY_FULL_GROUP_BY mode and compatibility with MySQL 5.7 ANY_VALUE function as a ONLY_FULL_GROUP_BY mode, SQL-2023-T626, and compatibility with MySQL 5.7
            serg Sergei Golubchik made changes -
            Summary ANY_VALUE function as a ONLY_FULL_GROUP_BY mode, SQL-2023-T626, and compatibility with MySQL 5.7 ANY_VALUE function as a workaround for ONLY_FULL_GROUP_BY mode, SQL-2023-T626, and compatibility with MySQL 5.7
            serg Sergei Golubchik made changes -
            Fix Version/s 11.5 [ 29506 ]
            Fix Version/s 11.4 [ 29301 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 11.6 [ 29515 ]
            Fix Version/s 11.5 [ 29506 ]
            ralf.gebhardt Ralf Gebhardt made changes -
            Fix Version/s 11.6 [ 29515 ]

            People

              psergei Sergei Petrunia
              musicpanda Wim Roffel
              Votes:
              14 Vote for this issue
              Watchers:
              16 Start watching this issue

              Dates

                Created:
                Updated:

                Git Integration

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