Details
-
Bug
-
Status: Closed (View Workflow)
-
Major
-
Resolution: Fixed
-
10.1.1
Description
Test case |
--enable_connect_log
|
create database db; |
use db; |
create table t1 (i int, c varchar(8)); |
insert into t1 values (1,'foo'),(2,'bar'),(3,'baz'),(4,'qux'); |
create view v1 as select * from t1 where i > 1; |
grant all on db.v1 to u1@localhost; |
|
--connect (con1,localhost,u1,,)
|
|
--error ER_TABLEACCESS_DENIED_ERROR
|
select * from db.t1; |
--error ER_TABLEACCESS_DENIED_ERROR
|
explain select * from db.t1; |
--error ER_TABLEACCESS_DENIED_ERROR
|
analyze select * from db.t1; |
|
select * from db.v1; |
--error ER_VIEW_NO_EXPLAIN
|
explain select * from db.v1; |
--error ER_VIEW_NO_EXPLAIN
|
analyze select * from db.v1; |
|
--disconnect con1
|
--connection default
|
|
drop user u1@localhost; |
drop database db; |
The last statement should fail just like the previous one does, but it succeeds (and reveals the underlying t1 table in the output).
Same for INSERT, UPDATE, DELETE.
review feedback provided over email