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

Crash in Field_string::type_handler when calling procedures

Details

    Description

      CREATE TABLE t (f INT);
       
      --delimiter $
      CREATE TRIGGER tr AFTER INSERT ON t FOR EACH ROW
          FOR x IN (SELECT * FROM json_table(NULL, '$' COLUMNS(a CHAR(1) path '$.*')) tmp)  
          DO set @a=1; END FOR $
      --delimiter ;
       
      INSERT INTO t () values ();
       
      # Cleanup
      DROP TABLE t;
      

      Attachments

        Activity

          Fix for 10.6, but I think it will be better to push it in 10.6 with the test and in 10.3 without test (syntax is incompatible).

          commit e3e59c9e38d5405942b6449a2cdc044e67c27790 (HEAD -> bb-10.6-MDEV-28266, origin/bb-10.6-MDEV-28266)
          Author: Oleksandr Byelkin <sanja@mariadb.com>
          Date:   Fri Apr 8 10:37:17 2022 +0200
           
              MDEV-28266 Crash in Field_string::type_handler when calling procedures
              
              In case of only metadata request the cursor lack the call to redirect
              Field::orig_table to the temporary table.
          

          sanja Oleksandr Byelkin added a comment - Fix for 10.6, but I think it will be better to push it in 10.6 with the test and in 10.3 without test (syntax is incompatible). commit e3e59c9e38d5405942b6449a2cdc044e67c27790 (HEAD -> bb-10.6-MDEV-28266, origin/bb-10.6-MDEV-28266) Author: Oleksandr Byelkin <sanja@mariadb.com> Date: Fri Apr 8 10:37:17 2022 +0200   MDEV-28266 Crash in Field_string::type_handler when calling procedures In case of only metadata request the cursor lack the call to redirect Field::orig_table to the temporary table.
          sanja Oleksandr Byelkin added a comment - - edited

          commit 4218c3b1cfcb0af7268a45df34861d954ded29f0 (HEAD -> bb-10.6-MDEV-28266, origin/bb-10.6-MDEV-28266)
          Author: Oleksandr Byelkin <sanja@mariadb.com>
          Date:   Fri Apr 8 10:37:17 2022 +0200
           
              MDEV-28266 Crash in Field_string::type_handler when calling procedures
              
              on_table_fill_finished() should always be done at the end of open()
              even if result is not Select_materialize but (for example)
              Select_fetch_into_spvars.
          

          sanja Oleksandr Byelkin added a comment - - edited commit 4218c3b1cfcb0af7268a45df34861d954ded29f0 (HEAD -> bb-10.6-MDEV-28266, origin/bb-10.6-MDEV-28266) Author: Oleksandr Byelkin <sanja@mariadb.com> Date: Fri Apr 8 10:37:17 2022 +0200   MDEV-28266 Crash in Field_string::type_handler when calling procedures on_table_fill_finished() should always be done at the end of open() even if result is not Select_materialize but (for example) Select_fetch_into_spvars.

          4218c3b1cfcb0af7268a45df34861d954ded29f0 is ok to push (presuming it passes all tests, as always. I didn't check buildbot myself)

          serg Sergei Golubchik added a comment - 4218c3b1cfcb0af7268a45df34861d954ded29f0 is ok to push (presuming it passes all tests, as always. I didn't check buildbot myself)

          People

            sanja Oleksandr Byelkin
            sanja Oleksandr Byelkin
            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.