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

type error when setting session variable

Details

    • 10.1.13

    Description

      The following query fails:

      • SET SESSION wait_timeout = GREATEST(28000, @@wait_timeout)

      Error:
      #1232 - Incorrect argument type to variable 'wait_timeout`

      There should be no type conversion issue as those queries work:

      • SET SESSION wait_timeout = 28000;
      • SET SESSION wait_timeout = @@wait_timeout;
      • SELECT GREATEST(28000, @@wait_timeout);

      please see this SO question for detail:
      http://stackoverflow.com/questions/35187378/mariadb-type-error-when-setting-session-variable

      Attachments

        Activity

          mvo Moritz Vondano created issue -
          elenst Elena Stepanova made changes -
          Field Original Value New Value
          Status Open [ 1 ] Confirmed [ 10101 ]

          Thanks for the report.

          The problem was introduced by this commit:

          commit 09b87d6293b4b41321ba98366d5d7ade9ad681d3
          Author: Alexander Barkov <bar@mariadb.org>
          Date:   Wed Sep 30 10:05:16 2015 +0400
           
              MDEV-8871 Wrong result for CREATE TABLE .. SELECT LEAST(unsigned_column,unsigned_column)

          elenst Elena Stepanova added a comment - Thanks for the report. The problem was introduced by this commit: commit 09b87d6293b4b41321ba98366d5d7ade9ad681d3 Author: Alexander Barkov <bar@mariadb.org> Date: Wed Sep 30 10:05:16 2015 +0400   MDEV-8871 Wrong result for CREATE TABLE .. SELECT LEAST(unsigned_column,unsigned_column)
          elenst Elena Stepanova made changes -
          Fix Version/s 10.1 [ 16100 ]
          Affects Version/s 10.1 [ 16100 ]
          Assignee Alexander Barkov [ bar ]
          Labels regression
          ratzpo Rasmus Johansson (Inactive) made changes -
          Sprint 10.1.13 [ 42 ]
          ratzpo Rasmus Johansson (Inactive) made changes -
          Rank Ranked lower

          Note, the same problem is repeatable in 10.0 with other hybrid type functions:

          SET SESSION wait_timeout = COALESCE(28000, @@wait_timeout);
          SET SESSION wait_timeout = IFNULL(28000, @@wait_timeout);
          SET SESSION wait_timeout = CASE WHEN TRUE THEN 28000 ELSE @@wait_timeout END;
          

          So the patch for MDEV-8871 only made LEAST detect its data type consistently with COALESCE, IFNULL, CASE.
          The problem was not really "introduced" by MDEV-8871.
          It exists for a long time and should be fixed for all hybrid functions at once.

          bar Alexander Barkov added a comment - Note, the same problem is repeatable in 10.0 with other hybrid type functions: SET SESSION wait_timeout = COALESCE(28000, @@wait_timeout); SET SESSION wait_timeout = IFNULL(28000, @@wait_timeout); SET SESSION wait_timeout = CASE WHEN TRUE THEN 28000 ELSE @@wait_timeout END; So the patch for MDEV-8871 only made LEAST detect its data type consistently with COALESCE, IFNULL, CASE. The problem was not really "introduced" by MDEV-8871 . It exists for a long time and should be fixed for all hybrid functions at once.
          bar Alexander Barkov added a comment - - edited

          Possible fixes:
          1. Fix hybrid functions to fallback to INT or BIGINT if the result data type was detected as DECIMAL(N,0) with a small N.
          Note, fallback should work only if all arguments are of INT-alike types actually (and should keep DECIMAL if any of the arguments was DECIMAL).
          2. Fix int-type variables
          a. Accept assignment of a DECIMAL(N,0) expression with a small N.

          • Allow integer type variables to accept expressions of the DECIMAL(N, 0) type, providing that N fits into the underlying INT data type
          • Fix data type of @@wait_timeout to return INT(11), instead of BIGINT(21), otherwise the "N fits" requirement will be FALSE.

          b. Another option is just to accept all DECIMAL(N, 0), even if N is big enough, and produce a warning on overflow.

          c. Another option is to accept all DECIMAL(N,M), even if M>0, and produce a warning on fraction truncation.

          bar Alexander Barkov added a comment - - edited Possible fixes: 1. Fix hybrid functions to fallback to INT or BIGINT if the result data type was detected as DECIMAL(N,0) with a small N. Note, fallback should work only if all arguments are of INT-alike types actually (and should keep DECIMAL if any of the arguments was DECIMAL). 2. Fix int-type variables a. Accept assignment of a DECIMAL(N,0) expression with a small N. Allow integer type variables to accept expressions of the DECIMAL(N, 0) type, providing that N fits into the underlying INT data type Fix data type of @@wait_timeout to return INT(11), instead of BIGINT(21), otherwise the "N fits" requirement will be FALSE. b. Another option is just to accept all DECIMAL(N, 0), even if N is big enough, and produce a warning on overflow. c. Another option is to accept all DECIMAL(N,M), even if M>0, and produce a warning on fraction truncation.

          During a discussion, Serg and Bar decided to accept DECIMAL(N,0), no matter if N is big enough, and produce an error if the value does not fit.

          bar Alexander Barkov added a comment - During a discussion, Serg and Bar decided to accept DECIMAL(N,0), no matter if N is big enough, and produce an error if the value does not fit.
          bar Alexander Barkov made changes -
          Fix Version/s 10.0 [ 16000 ]
          bar Alexander Barkov made changes -
          Fix Version/s 10.0 [ 16000 ]
          bar Alexander Barkov made changes -
          Status Confirmed [ 10101 ] In Progress [ 3 ]
          bar Alexander Barkov made changes -
          Assignee Alexander Barkov [ bar ] Sergei Golubchik [ serg ]
          Status In Progress [ 3 ] In Review [ 10002 ]

          ok to push

          serg Sergei Golubchik added a comment - ok to push
          serg Sergei Golubchik made changes -
          Assignee Sergei Golubchik [ serg ] Alexander Barkov [ bar ]
          Status In Review [ 10002 ] Stalled [ 10000 ]
          bar Alexander Barkov made changes -
          Component/s OTHER [ 10125 ]
          Fix Version/s 10.1.13 [ 21803 ]
          Fix Version/s 10.1 [ 16100 ]
          Resolution Fixed [ 1 ]
          Status Stalled [ 10000 ] Closed [ 6 ]
          serg Sergei Golubchik made changes -
          Component/s Admin statements [ 11400 ]
          Component/s OTHER [ 10125 ]
          serg Sergei Golubchik made changes -
          Workflow MariaDB v3 [ 73872 ] MariaDB v4 [ 150079 ]

          People

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