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

Strange error message if you try to FLUSH TABLES <view> after LOCK TABLES <view>

Details

    Description

      If you try to execute FLUSH TABLES on a view after read-locking that view with LOCK TABLES ... READ|WRITE, then you get an error message that doesn't seem to make a lot of sense.

      For example, if we have this view:

      CREATE TABLE t (qty INT, price INT);
      CREATE VIEW v AS SELECT qty, price, qty*price AS value FROM t;
      

      Then let's see what happens:

      MariaDB [db1]> LOCK TABLES v READ;
      Query OK, 0 rows affected (0.00 sec)
       
      MariaDB [db1]> FLUSH TABLES v;
      ERROR 1100 (HY000): Table 'v' was not locked with LOCK TABLES
      

      If we execute the same statement on the base table, then we get a different error message:

      MariaDB [db1]> LOCK TABLES t READ;
      Query OK, 0 rows affected (0.00 sec)
       
      MariaDB [db1]> FLUSH TABLES t;
      ERROR 1099 (HY000): Table 't' was locked with a READ lock and can't be updated
      

      Trying to flush a write-locked view has the same problem:

      MariaDB [db1]> LOCK TABLES v WRITE;
      Query OK, 0 rows affected (0.00 sec)
       
      MariaDB [db1]> FLUSH TABLES v;
      ERROR 1100 (HY000): Table 'v' was not locked with LOCK TABLES
      

      But this does work for base tables:

      MariaDB [db1]> LOCK TABLES t WRITE;
      Query OK, 0 rows affected (0.00 sec)
       
      MariaDB [db1]> FLUSH TABLES t;
      Query OK, 0 rows affected (0.00 sec)
      

      Is the error message wrong, or is FLUSH partially broken for views at the moment?

      Attachments

        Issue Links

          Activity

            GeoffMontee Geoff Montee (Inactive) created issue -
            GeoffMontee Geoff Montee (Inactive) made changes -
            Field Original Value New Value
            Summary Wrong error message if you try to FLUSH TABLES <view> after LOCK TABLES <view> READ Strange error message if you try to FLUSH TABLES <view> after LOCK TABLES <view>
            GeoffMontee Geoff Montee (Inactive) made changes -
            Description If you try to execute FLUSH TABLES on a view after read-locking that view with LOCK TABLES ... READ, then you get an error message that doesn't seem to make a lot of sense.

            For example, if we have this view:

            {noformat}
            CREATE TABLE t (qty INT, price INT);
            CREATE VIEW v AS SELECT qty, price, qty*price AS value FROM t;
            {noformat}

            Then let's see what happens:

            {noformat}
            MariaDB [db1]> LOCK TABLES v READ;
            Query OK, 0 rows affected (0.00 sec)

            MariaDB [db1]> FLUSH TABLES v;
            ERROR 1100 (HY000): Table 'v' was not locked with LOCK TABLES
            {noformat}

            If we execute the same statement on the base table, then we get a different error message:

            {noformat}
            MariaDB [db1]> LOCK TABLES t READ;
            Query OK, 0 rows affected (0.00 sec)

            MariaDB [db1]> FLUSH TABLES t;
            ERROR 1099 (HY000): Table 't' was locked with a READ lock and can't be updated
            {noformat}
            If you try to execute FLUSH TABLES on a view after read-locking that view with LOCK TABLES ... READ|WRITE, then you get an error message that doesn't seem to make a lot of sense.

            For example, if we have this view:

            {noformat}
            CREATE TABLE t (qty INT, price INT);
            CREATE VIEW v AS SELECT qty, price, qty*price AS value FROM t;
            {noformat}

            Then let's see what happens:

            {noformat}
            MariaDB [db1]> LOCK TABLES v READ;
            Query OK, 0 rows affected (0.00 sec)

            MariaDB [db1]> FLUSH TABLES v;
            ERROR 1100 (HY000): Table 'v' was not locked with LOCK TABLES
            {noformat}

            If we execute the same statement on the base table, then we get a different error message:

            {noformat}
            MariaDB [db1]> LOCK TABLES t READ;
            Query OK, 0 rows affected (0.00 sec)

            MariaDB [db1]> FLUSH TABLES t;
            ERROR 1099 (HY000): Table 't' was locked with a READ lock and can't be updated
            {noformat}

            Trying to flush a write-locked view has the same problem:

            {noformat}
            MariaDB [db1]> LOCK TABLES v WRITE;
            Query OK, 0 rows affected (0.00 sec)

            MariaDB [db1]> FLUSH TABLES v;
            ERROR 1100 (HY000): Table 'v' was not locked with LOCK TABLES
            {noformat}

            But this does work for base tables:

            {noformat}
            MariaDB [db1]> LOCK TABLES t WRITE;
            Query OK, 0 rows affected (0.00 sec)

            MariaDB [db1]> FLUSH TABLES t;
            Query OK, 0 rows affected (0.00 sec)
            {noformat}

            Is the error message wrong, or is FLUSH partially broken for views at the moment?
            elenst Elena Stepanova made changes -
            Component/s Locking [ 10900 ]
            Fix Version/s 10.2 [ 14601 ]
            Assignee Sergey Vojtovich [ svoj ]
            serg Sergei Golubchik made changes -
            Affects Version/s 10.2 [ 14601 ]
            Affects Version/s 10.3 [ 22126 ]
            Affects Version/s 5.5 [ 15800 ]
            Affects Version/s 10.0 [ 16000 ]
            Affects Version/s 10.1 [ 16100 ]
            Affects Version/s 10.2.14 [ 22911 ]
            serg Sergei Golubchik made changes -
            Fix Version/s N/A [ 14700 ]
            Fix Version/s 10.2 [ 14601 ]
            Assignee Sergey Vojtovich [ svoj ] Sergei Golubchik [ serg ]
            Resolution Not a Bug [ 6 ]
            Status Open [ 1 ] Closed [ 6 ]
            serg Sergei Golubchik made changes -
            Assignee Sergei Golubchik [ serg ] Alexey Botchkov [ holyfoot ]
            Resolution Not a Bug [ 6 ]
            Status Closed [ 6 ] Stalled [ 10000 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 10.2 [ 14601 ]
            Fix Version/s 10.3 [ 22126 ]
            Fix Version/s 10.1 [ 16100 ]
            Fix Version/s N/A [ 14700 ]
            holyfoot Alexey Botchkov made changes -
            Status Stalled [ 10000 ] In Progress [ 3 ]
            holyfoot Alexey Botchkov made changes -
            Assignee Alexey Botchkov [ holyfoot ] Sergei Golubchik [ serg ]
            Status In Progress [ 3 ] In Review [ 10002 ]
            serg Sergei Golubchik made changes -
            Assignee Sergei Golubchik [ serg ] Alexey Botchkov [ holyfoot ]
            Status In Review [ 10002 ] Stalled [ 10000 ]
            julien.fritsch Julien Fritsch made changes -
            Comment [ A comment with security level 'Developers' was removed. ]
            holyfoot Alexey Botchkov made changes -
            Status Stalled [ 10000 ] In Progress [ 3 ]
            holyfoot Alexey Botchkov made changes -
            Assignee Alexey Botchkov [ holyfoot ] Sergei Golubchik [ serg ]
            Status In Progress [ 3 ] In Review [ 10002 ]
            serg Sergei Golubchik made changes -
            Assignee Sergei Golubchik [ serg ] Alexey Botchkov [ holyfoot ]
            Status In Review [ 10002 ] Stalled [ 10000 ]
            holyfoot Alexey Botchkov made changes -
            Status Stalled [ 10000 ] In Progress [ 3 ]
            holyfoot Alexey Botchkov made changes -
            Fix Version/s 10.1.36 [ 23117 ]
            Fix Version/s 10.2 [ 14601 ]
            Fix Version/s 10.1 [ 16100 ]
            Fix Version/s 10.3 [ 22126 ]
            Resolution Fixed [ 1 ]
            Status In Progress [ 3 ] Closed [ 6 ]
            holyfoot Alexey Botchkov made changes -
            Resolution Fixed [ 1 ]
            Status Closed [ 6 ] Stalled [ 10000 ]
            holyfoot Alexey Botchkov made changes -
            Assignee Alexey Botchkov [ holyfoot ] Sergei Golubchik [ serg ]
            Status Stalled [ 10000 ] In Review [ 10002 ]
            serg Sergei Golubchik made changes -
            Assignee Sergei Golubchik [ serg ] Alexey Botchkov [ holyfoot ]
            Status In Review [ 10002 ] Stalled [ 10000 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 10.1 [ 16100 ]
            Fix Version/s 10.1.36 [ 23117 ]
            holyfoot Alexey Botchkov made changes -
            Assignee Alexey Botchkov [ holyfoot ] Sergei Golubchik [ serg ]
            Status Stalled [ 10000 ] In Review [ 10002 ]
            ratzpo Rasmus Johansson (Inactive) made changes -
            julien.fritsch Julien Fritsch made changes -
            Priority Major [ 3 ] Critical [ 2 ]
            serg Sergei Golubchik made changes -
            Assignee Sergei Golubchik [ serg ] Alexey Botchkov [ holyfoot ]
            Status In Review [ 10002 ] Stalled [ 10000 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 10.2 [ 14601 ]
            serg Sergei Golubchik made changes -
            Fix Version/s 10.3 [ 22126 ]
            holyfoot Alexey Botchkov made changes -
            Fix Version/s 10.1.38 [ 23209 ]
            Fix Version/s 10.2 [ 14601 ]
            Fix Version/s 10.1 [ 16100 ]
            Fix Version/s 10.3 [ 22126 ]
            Resolution Fixed [ 1 ]
            Status Stalled [ 10000 ] Closed [ 6 ]
            holyfoot Alexey Botchkov made changes -
            Fix Version/s 10.3.11 [ 23141 ]
            Fix Version/s 10.2.19 [ 23207 ]
            serg Sergei Golubchik made changes -
            Workflow MariaDB v3 [ 86584 ] MariaDB v4 [ 154167 ]
            mariadb-jira-automation Jira Automation (IT) made changes -
            Zendesk Related Tickets 163917

            People

              holyfoot Alexey Botchkov
              GeoffMontee Geoff Montee (Inactive)
              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.