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

Crash in CREATE OR REPLACE TABLE t1 AS SELECT spfunc()

Details

    • Bug
    • Status: Closed (View Workflow)
    • Major
    • Resolution: Fixed
    • 10.0(EOL), 10.1(EOL)
    • 10.0.28, 10.1.19
    • Locking
    • None
    • 10.0.28

    Description

      This script crashes the server:

      CREATE TABLE IF NOT EXISTS t1 (i INT);
      DROP FUNCTION IF EXISTS f1;
      DELIMITER $$
      CREATE FUNCTION f1() RETURNS VARCHAR(16383)
      BEGIN
        RETURN 'test';
      END;
      $$
      DELIMITER ;
      CREATE OR REPLACE TABLE t1 AS SELECT f1();
      

      Note, if I replace CREATE OR REPLACE to a DROP followed by CREATE, it works fine:

      CREATE TABLE IF NOT EXISTS t1 (i INT);
      DROP FUNCTION IF EXISTS f1;
      DELIMITER $$
      CREATE FUNCTION f1() RETURNS VARCHAR(16383)
      BEGIN
        RETURN 'test';
      END;
      $$
      DELIMITER ;
      DROP TABLE IF EXISTS t1;
      CREATE TABLE t1 AS SELECT f1();
      

      Attachments

        Issue Links

          Activity

            bar Alexander Barkov created issue -
            bar Alexander Barkov made changes -
            Field Original Value New Value
            Description This script crashes the server:
            {code:sql}
            DROP FUNCTION IF EXISTS f1;
            DELIMITER $$
            CREATE FUNCTION f1() RETURNS VARCHAR(16383)
            BEGIN
              RETURN 'test';
            END;
            $$
            DELIMITER ;
            CREATE OR REPLACE TABLE t1 AS SELECT f1();
            {code}

            Note, if I replace {{CREATE OR REPLACE}} to a {{DROP}} followed by {{CREATE}}, it works fine:
            {code:sql}
            DROP FUNCTION IF EXISTS f1;
            DELIMITER $$
            CREATE FUNCTION f1() RETURNS VARCHAR(16383)
            BEGIN
              RETURN 'test';
            END;
            $$
            DELIMITER ;
            DROP TABLE IF EXISTS t1;
            CREATE TABLE t1 AS SELECT f1();
            CREATE OR REPLACE TABLE t1 AS SELECT f1();
            {code}
            This script crashes the server:
            {code:sql}
            DROP FUNCTION IF EXISTS f1;
            DELIMITER $$
            CREATE FUNCTION f1() RETURNS VARCHAR(16383)
            BEGIN
              RETURN 'test';
            END;
            $$
            DELIMITER ;
            CREATE OR REPLACE TABLE t1 AS SELECT f1();
            {code}

            Note, if I replace {{CREATE OR REPLACE}} to a {{DROP}} followed by {{CREATE}}, it works fine:
            {code:sql}
            DROP FUNCTION IF EXISTS f1;
            DELIMITER $$
            CREATE FUNCTION f1() RETURNS VARCHAR(16383)
            BEGIN
              RETURN 'test';
            END;
            $$
            DELIMITER ;
            DROP TABLE IF EXISTS t1;
            CREATE TABLE t1 AS SELECT f1();
            {code}
            elenst Elena Stepanova made changes -
            Description This script crashes the server:
            {code:sql}
            DROP FUNCTION IF EXISTS f1;
            DELIMITER $$
            CREATE FUNCTION f1() RETURNS VARCHAR(16383)
            BEGIN
              RETURN 'test';
            END;
            $$
            DELIMITER ;
            CREATE OR REPLACE TABLE t1 AS SELECT f1();
            {code}

            Note, if I replace {{CREATE OR REPLACE}} to a {{DROP}} followed by {{CREATE}}, it works fine:
            {code:sql}
            DROP FUNCTION IF EXISTS f1;
            DELIMITER $$
            CREATE FUNCTION f1() RETURNS VARCHAR(16383)
            BEGIN
              RETURN 'test';
            END;
            $$
            DELIMITER ;
            DROP TABLE IF EXISTS t1;
            CREATE TABLE t1 AS SELECT f1();
            {code}
            This script crashes the server:
            {code:sql}
            CREATE TABLE IF NOT EXISTS t1 (i INT);
            DROP FUNCTION IF EXISTS f1;
            DELIMITER $$
            CREATE FUNCTION f1() RETURNS VARCHAR(16383)
            BEGIN
              RETURN 'test';
            END;
            $$
            DELIMITER ;
            CREATE OR REPLACE TABLE t1 AS SELECT f1();
            {code}

            Note, if I replace {{CREATE OR REPLACE}} to a {{DROP}} followed by {{CREATE}}, it works fine:
            {code:sql}
            CREATE TABLE IF NOT EXISTS t1 (i INT);
            DROP FUNCTION IF EXISTS f1;
            DELIMITER $$
            CREATE FUNCTION f1() RETURNS VARCHAR(16383)
            BEGIN
              RETURN 'test';
            END;
            $$
            DELIMITER ;
            DROP TABLE IF EXISTS t1;
            CREATE TABLE t1 AS SELECT f1();
            {code}
            elenst Elena Stepanova made changes -
            Assignee Sergey Vojtovich [ svoj ]
            elenst Elena Stepanova made changes -
            Fix Version/s 10.1 [ 16100 ]
            elenst Elena Stepanova made changes -
            Affects Version/s 10.2 [ 14601 ]
            ratzpo Rasmus Johansson (Inactive) made changes -
            Sprint 10.0.28 [ 107 ]
            ratzpo Rasmus Johansson (Inactive) made changes -
            Rank Ranked lower
            svoj Sergey Vojtovich made changes -
            Assignee Sergey Vojtovich [ svoj ] Sergei Golubchik [ serg ]
            Status Open [ 1 ] In Review [ 10002 ]
            svoj Sergey Vojtovich made changes -
            serg Sergei Golubchik made changes -
            Assignee Sergei Golubchik [ serg ] Sergey Vojtovich [ svoj ]
            Status In Review [ 10002 ] Stalled [ 10000 ]
            svoj Sergey Vojtovich made changes -
            Component/s OTHER [ 10125 ]
            Fix Version/s 10.0.28 [ 22107 ]
            Fix Version/s 10.1.19 [ 22111 ]
            Fix Version/s 10.0 [ 16000 ]
            Fix Version/s 10.1 [ 16100 ]
            Resolution Fixed [ 1 ]
            Status Stalled [ 10000 ] Closed [ 6 ]
            serg Sergei Golubchik made changes -
            Component/s Locking [ 10900 ]
            Component/s OTHER [ 10125 ]
            elenst Elena Stepanova made changes -
            serg Sergei Golubchik made changes -
            Workflow MariaDB v3 [ 77121 ] MariaDB v4 [ 150925 ]

            People

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