2000-12-28 02:56:38 +01:00
|
|
|
|
#
|
2011-03-24 11:27:11 +01:00
|
|
|
|
# Test of different EXPLAINs
|
2000-12-28 02:56:38 +01:00
|
|
|
|
|
2003-01-06 00:48:59 +01:00
|
|
|
|
--disable_warnings
|
2000-12-28 02:56:38 +01:00
|
|
|
|
drop table if exists t1;
|
2003-01-06 00:48:59 +01:00
|
|
|
|
--enable_warnings
|
2000-12-28 02:56:38 +01:00
|
|
|
|
create table t1 (id int not null, str char(10), unique(str));
|
2003-01-20 17:17:14 +01:00
|
|
|
|
explain select * from t1;
|
2000-12-28 02:56:38 +01:00
|
|
|
|
insert into t1 values (1, null),(2, null),(3, "foo"),(4, "bar");
|
|
|
|
|
select * from t1 where str is null;
|
|
|
|
|
select * from t1 where str="foo";
|
|
|
|
|
explain select * from t1 where str is null;
|
|
|
|
|
explain select * from t1 where str="foo";
|
|
|
|
|
explain select * from t1 ignore key (str) where str="foo";
|
|
|
|
|
explain select * from t1 use key (str,str) where str="foo";
|
|
|
|
|
|
|
|
|
|
#The following should give errors
|
Fixed bug #17873: confusing error message when IGNORE/USE/FORCE INDEX
refers to a column name.
mysql-test/r/select.result:
Fixed bug #17873: confusing error message when IGNORE/USE/FORCE INDEX
refers to a column name.
Added a new test case.
mysql-test/t/select.test:
Fixed bug #17873: confusing error message when IGNORE/USE/FORCE INDEX
refers to a column name.
Added a new test case.
sql/share/czech/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/danish/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/dutch/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/english/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/estonian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/french/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/german/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/greek/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.\
sql/share/hungarian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/italian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/japanese-sjis/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.\
sql/share/japanese/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/korean/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/norwegian-ny/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/norwegian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/polish/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/portuguese/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/romanian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/russian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/serbian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/slovak/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/spanish/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/swedish/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/ukrainian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
2006-05-30 09:08:58 +02:00
|
|
|
|
--error 1176
|
2003-01-20 17:17:14 +01:00
|
|
|
|
explain select * from t1 use key (str,str,foo) where str="foo";
|
Fixed bug #17873: confusing error message when IGNORE/USE/FORCE INDEX
refers to a column name.
mysql-test/r/select.result:
Fixed bug #17873: confusing error message when IGNORE/USE/FORCE INDEX
refers to a column name.
Added a new test case.
mysql-test/t/select.test:
Fixed bug #17873: confusing error message when IGNORE/USE/FORCE INDEX
refers to a column name.
Added a new test case.
sql/share/czech/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/danish/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/dutch/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/english/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/estonian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/french/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/german/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/greek/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.\
sql/share/hungarian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/italian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/japanese-sjis/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.\
sql/share/japanese/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/korean/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/norwegian-ny/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/norwegian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/polish/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/portuguese/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/romanian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/russian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/serbian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/slovak/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/spanish/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/swedish/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
sql/share/ukrainian/errmsg.txt:
Removed error message ER_INDEX_DOES_NOT_EXIST,
used ER_KEY_DOES_NOT_EXITS instead.
2006-05-30 09:08:58 +02:00
|
|
|
|
--error 1176
|
2003-01-20 17:17:14 +01:00
|
|
|
|
explain select * from t1 ignore key (str,str,foo) where str="foo";
|
2000-12-28 02:56:38 +01:00
|
|
|
|
drop table t1;
|
|
|
|
|
|
|
|
|
|
explain select 1;
|
2003-02-07 16:57:07 +01:00
|
|
|
|
|
|
|
|
|
create table t1 (a int not null);
|
|
|
|
|
explain select count(*) from t1;
|
|
|
|
|
insert into t1 values(1);
|
|
|
|
|
explain select count(*) from t1;
|
|
|
|
|
insert into t1 values(1);
|
|
|
|
|
explain select count(*) from t1;
|
|
|
|
|
drop table t1;
|
2004-05-14 10:08:22 +02:00
|
|
|
|
|
|
|
|
|
#
|
|
|
|
|
# Bug #3403 Wrong encoding in EXPLAIN SELECT output
|
|
|
|
|
#
|
|
|
|
|
set names koi8r;
|
|
|
|
|
create table <20><><EFBFBD> (<28><><EFBFBD>0 int, <20><><EFBFBD>1 int, key <20><><EFBFBD>0 (<28><><EFBFBD>0), key <20><><EFBFBD>01 (<28><><EFBFBD>0,<2C><><EFBFBD>1));
|
|
|
|
|
insert into <20><><EFBFBD> (<28><><EFBFBD>0) values (1);
|
|
|
|
|
insert into <20><><EFBFBD> (<28><><EFBFBD>0) values (2);
|
|
|
|
|
explain select <20><><EFBFBD>0 from <20><><EFBFBD> where <20><><EFBFBD>0=1;
|
|
|
|
|
drop table <20><><EFBFBD>;
|
|
|
|
|
set names latin1;
|
2005-07-28 02:22:47 +02:00
|
|
|
|
|
|
|
|
|
# End of 4.1 tests
|
2006-05-03 16:02:43 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
|
# Bug#15463: EXPLAIN SELECT..INTO hangs the client (QB, command line)
|
|
|
|
|
#
|
|
|
|
|
select 3 into @v1;
|
|
|
|
|
explain select 3 into @v1;
|
|
|
|
|
|
2007-03-07 19:44:58 +01:00
|
|
|
|
#
|
|
|
|
|
# Bug#22331: Wrong WHERE in EXPLAIN EXTENDED when all expressions were
|
|
|
|
|
# optimized away.
|
|
|
|
|
#
|
|
|
|
|
create table t1(f1 int, f2 int);
|
|
|
|
|
insert into t1 values (1,1);
|
|
|
|
|
create view v1 as select * from t1 where f1=1;
|
|
|
|
|
explain extended select * from v1 where f2=1;
|
|
|
|
|
explain extended select * from t1 where 0;
|
|
|
|
|
explain extended select * from t1 where 1;
|
|
|
|
|
explain extended select * from t1 having 0;
|
|
|
|
|
explain extended select * from t1 having 1;
|
2007-03-07 22:27:42 +01:00
|
|
|
|
drop view v1;
|
2007-03-07 19:44:58 +01:00
|
|
|
|
drop table t1;
|
|
|
|
|
|
2007-11-16 11:58:09 +01:00
|
|
|
|
#
|
|
|
|
|
# Bug #32241: memory corruption due to large index map in 'Range checked for
|
|
|
|
|
# each record'
|
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
CREATE TABLE t1(c INT);
|
|
|
|
|
INSERT INTO t1 VALUES (),();
|
|
|
|
|
|
|
|
|
|
CREATE TABLE t2 (b INT,
|
|
|
|
|
KEY(b),KEY(b),KEY(b),KEY(b),KEY(b),
|
|
|
|
|
KEY(b),KEY(b),KEY(b),KEY(b),KEY(b),
|
|
|
|
|
KEY(b),KEY(b),KEY(b),KEY(b),KEY(b),
|
|
|
|
|
KEY(b),KEY(b),KEY(b),KEY(b),KEY(b),
|
|
|
|
|
KEY(b),KEY(b),KEY(b),KEY(b),KEY(b),
|
|
|
|
|
KEY(b),KEY(b),KEY(b),KEY(b),KEY(b),
|
|
|
|
|
KEY(b),KEY(b),KEY(b),KEY(b),KEY(b),
|
|
|
|
|
KEY(b),KEY(b),KEY(b),KEY(b),KEY(b));
|
|
|
|
|
|
|
|
|
|
INSERT INTO t2 VALUES (),(),();
|
|
|
|
|
|
|
|
|
|
# We only need to make sure that there is no buffer overrun and the index map
|
|
|
|
|
# is displayed correctly
|
|
|
|
|
--replace_column 1 X 2 X 3 X 4 X 5 X 6 X 7 X 8 X 9 X
|
|
|
|
|
EXPLAIN SELECT 1 FROM
|
|
|
|
|
(SELECT 1 FROM t2,t1 WHERE b < c GROUP BY 1 LIMIT 1) AS d2;
|
|
|
|
|
DROP TABLE t2;
|
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
|
2008-10-06 16:17:25 +02:00
|
|
|
|
#
|
|
|
|
|
# Bug #34773: query with explain extended and derived table / other table
|
|
|
|
|
# crashes server
|
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
CREATE TABLE t1(a INT);
|
|
|
|
|
CREATE TABLE t2(a INT);
|
|
|
|
|
INSERT INTO t1 VALUES (1),(2);
|
|
|
|
|
INSERT INTO t2 VALUES (1),(2);
|
|
|
|
|
|
|
|
|
|
EXPLAIN EXTENDED SELECT 1
|
|
|
|
|
FROM (SELECT COUNT(DISTINCT t1.a) FROM t1,t2 GROUP BY t1.a) AS s1;
|
|
|
|
|
|
|
|
|
|
EXPLAIN EXTENDED SELECT 1
|
|
|
|
|
FROM (SELECT COUNT(DISTINCT t1.a) FROM t1,t2 GROUP BY t1.a) AS s1;
|
|
|
|
|
|
|
|
|
|
prepare s1 from
|
|
|
|
|
'EXPLAIN EXTENDED SELECT 1
|
|
|
|
|
FROM (SELECT COUNT(DISTINCT t1.a) FROM t1,t2 GROUP BY t1.a) AS s1';
|
|
|
|
|
execute s1;
|
|
|
|
|
|
|
|
|
|
prepare s1 from
|
|
|
|
|
'EXPLAIN EXTENDED SELECT 1
|
|
|
|
|
FROM (SELECT COUNT(DISTINCT t1.a) FROM t1,t2 GROUP BY t1.a) AS s1';
|
|
|
|
|
execute s1;
|
|
|
|
|
execute s1;
|
|
|
|
|
|
|
|
|
|
DROP TABLE t1,t2;
|
|
|
|
|
|
2009-03-11 13:10:44 +01:00
|
|
|
|
|
|
|
|
|
#
|
|
|
|
|
# Bug #43354: Use key hint can crash server in explain extended query
|
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
CREATE TABLE t1 (a INT PRIMARY KEY);
|
|
|
|
|
|
|
|
|
|
--error ER_KEY_DOES_NOT_EXITS
|
|
|
|
|
EXPLAIN EXTENDED SELECT COUNT(a) FROM t1 USE KEY(a);
|
|
|
|
|
|
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
|
2009-09-04 09:20:53 +02:00
|
|
|
|
#
|
|
|
|
|
# Bug#45989 memory leak after explain encounters an error in the query
|
|
|
|
|
#
|
|
|
|
|
CREATE TABLE t1(a LONGTEXT);
|
|
|
|
|
INSERT INTO t1 VALUES (repeat('a',@@global.max_allowed_packet));
|
|
|
|
|
INSERT INTO t1 VALUES (repeat('b',@@global.max_allowed_packet));
|
|
|
|
|
--error ER_BAD_FIELD_ERROR
|
|
|
|
|
EXPLAIN SELECT DISTINCT 1 FROM t1,
|
|
|
|
|
(SELECT DISTINCTROW a AS away FROM t1 GROUP BY a WITH ROLLUP) as d1
|
|
|
|
|
WHERE t1.a = d1.a;
|
|
|
|
|
DROP TABLE t1;
|
2009-03-11 13:10:44 +01:00
|
|
|
|
|
2009-10-30 00:01:54 +01:00
|
|
|
|
--echo #
|
|
|
|
|
--echo # Bug#48295:
|
|
|
|
|
--echo # explain extended crash with subquery and ONLY_FULL_GROUP_BY sql_mode
|
|
|
|
|
--echo #
|
|
|
|
|
|
2011-09-02 09:11:13 +02:00
|
|
|
|
CREATE TABLE t1 (f1 INT not null);
|
2009-10-30 00:01:54 +01:00
|
|
|
|
|
|
|
|
|
SELECT @@session.sql_mode INTO @old_sql_mode;
|
|
|
|
|
SET SESSION sql_mode='ONLY_FULL_GROUP_BY';
|
|
|
|
|
|
|
|
|
|
# EXPLAIN EXTENDED (with subselect). used to crash. should give NOTICE.
|
2011-05-04 17:08:58 +02:00
|
|
|
|
# Before moving max/min optimization to optimize phase this statement
|
|
|
|
|
# generated error, but as far as original query do not contain aggregate
|
|
|
|
|
# function user should not see error
|
|
|
|
|
# --error ER_MIX_OF_GROUP_FUNC_AND_FIELDS
|
2009-10-30 00:01:54 +01:00
|
|
|
|
EXPLAIN EXTENDED SELECT 1 FROM t1
|
|
|
|
|
WHERE f1 > ALL( SELECT t.f1 FROM t1,t1 AS t );
|
|
|
|
|
|
|
|
|
|
SET SESSION sql_mode=@old_sql_mode;
|
|
|
|
|
|
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
|
2010-03-02 19:00:53 +01:00
|
|
|
|
--echo End of 5.0 tests.
|
2009-03-11 13:29:59 +01:00
|
|
|
|
|
2008-10-27 10:26:32 +01:00
|
|
|
|
--echo #
|
|
|
|
|
--echo # Bug#37870: Usage of uninitialized value caused failed assertion.
|
|
|
|
|
--echo #
|
2008-11-05 16:40:23 +01:00
|
|
|
|
create table t1 (dt datetime not null, t time not null);
|
2008-10-27 10:26:32 +01:00
|
|
|
|
create table t2 (dt datetime not null);
|
2008-11-05 16:40:23 +01:00
|
|
|
|
insert into t1 values ('2001-01-01 1:1:1', '1:1:1'),
|
|
|
|
|
('2001-01-01 1:1:1', '1:1:1');
|
2008-10-27 10:26:32 +01:00
|
|
|
|
insert into t2 values ('2001-01-01 1:1:1'), ('2001-01-01 1:1:1');
|
2011-12-24 17:55:10 +01:00
|
|
|
|
SET @save_join_cache_level=@@join_cache_level;
|
|
|
|
|
SET join_cache_level=0;
|
2008-10-27 10:26:32 +01:00
|
|
|
|
flush tables;
|
|
|
|
|
EXPLAIN SELECT OUTR.dt FROM t1 AS OUTR WHERE OUTR.dt IN (SELECT INNR.dt FROM t2 AS INNR WHERE OUTR.dt IS NULL );
|
2008-11-05 16:40:23 +01:00
|
|
|
|
flush tables;
|
2008-10-27 10:26:32 +01:00
|
|
|
|
SELECT OUTR.dt FROM t1 AS OUTR WHERE OUTR.dt IN (SELECT INNR.dt FROM t2 AS INNR WHERE OUTR.dt IS NULL );
|
2008-11-05 16:40:23 +01:00
|
|
|
|
flush tables;
|
|
|
|
|
EXPLAIN SELECT OUTR.dt FROM t1 AS OUTR WHERE OUTR.dt IN ( SELECT INNR.dt FROM t2 AS INNR WHERE OUTR.t < '2005-11-13 7:41:31' );
|
|
|
|
|
flush tables;
|
|
|
|
|
SELECT OUTR.dt FROM t1 AS OUTR WHERE OUTR.dt IN ( SELECT INNR.dt FROM t2 AS INNR WHERE OUTR.t < '2005-11-13 7:41:31' );
|
2011-12-24 17:55:10 +01:00
|
|
|
|
SET join_cache_level=@save_join_cache_level;
|
2008-10-27 10:26:32 +01:00
|
|
|
|
drop tables t1, t2;
|
|
|
|
|
|
2009-10-30 00:01:54 +01:00
|
|
|
|
--echo #
|
2010-02-26 14:40:01 +01:00
|
|
|
|
--echo # Bug#47669: Query showed by EXPLAIN EXTENDED gives different result from original query
|
2009-10-30 00:01:54 +01:00
|
|
|
|
--echo #
|
|
|
|
|
|
2010-02-26 14:40:01 +01:00
|
|
|
|
CREATE TABLE t1 (c int);
|
|
|
|
|
INSERT INTO t1 VALUES (NULL);
|
|
|
|
|
CREATE TABLE t2 (d int);
|
|
|
|
|
INSERT INTO t2 VALUES (NULL), (0);
|
|
|
|
|
EXPLAIN EXTENDED SELECT (SELECT 1 FROM t2 WHERE d = c) FROM t1;
|
|
|
|
|
DROP TABLE t1, t2;
|
2009-10-19 13:13:26 +02:00
|
|
|
|
|
|
|
|
|
--echo #
|
|
|
|
|
--echo # Bug#30302: Tables that were optimized away are printed in the
|
|
|
|
|
--echo # EXPLAIN EXTENDED warning.
|
|
|
|
|
--echo #
|
|
|
|
|
create table t1(f1 int);
|
|
|
|
|
create table t2(f2 int);
|
|
|
|
|
insert into t1 values(1);
|
|
|
|
|
insert into t2 values(1),(2);
|
|
|
|
|
explain extended select * from t1 where f1=1;
|
|
|
|
|
explain extended select * from t1 join t2 on f1=f2 where f1=1;
|
|
|
|
|
drop table t1,t2;
|
2009-11-06 15:20:27 +01:00
|
|
|
|
|
2010-04-30 13:10:48 +02:00
|
|
|
|
--echo #
|
|
|
|
|
--echo # Bug #48419: another explain crash..
|
|
|
|
|
--echo #
|
|
|
|
|
CREATE TABLE t1 (a INT);
|
|
|
|
|
CREATE TABLE t2 (b BLOB, KEY b(b(100)));
|
|
|
|
|
INSERT INTO t2 VALUES ('1'), ('2'), ('3');
|
|
|
|
|
|
|
|
|
|
FLUSH TABLES;
|
|
|
|
|
|
|
|
|
|
EXPLAIN SELECT 1 FROM t1 WHERE a = (SELECT 1 FROM t1 t JOIN t2 WHERE b <= 1 AND t.a);
|
|
|
|
|
|
|
|
|
|
DROP TABLE t1, t2;
|
|
|
|
|
|
2010-05-29 20:16:45 +02:00
|
|
|
|
--echo #
|
|
|
|
|
--echo # Bug #48573: difference of index selection between rpm binary and
|
|
|
|
|
--echo # .tar.gz, windows vs linux..
|
|
|
|
|
--echo #
|
|
|
|
|
|
|
|
|
|
CREATE TABLE t1(c1 INT, c2 INT, c4 INT, c5 INT, KEY(c2, c5), KEY(c2, c4, c5));
|
|
|
|
|
INSERT INTO t1 VALUES(4, 1, 1, 1);
|
|
|
|
|
INSERT INTO t1 VALUES(3, 1, 1, 1);
|
|
|
|
|
INSERT INTO t1 VALUES(2, 1, 1, 1);
|
|
|
|
|
INSERT INTO t1 VALUES(1, 1, 1, 1);
|
|
|
|
|
|
|
|
|
|
EXPLAIN SELECT c1 FROM t1 WHERE c2 = 1 AND c4 = 1 AND c5 = 1;
|
|
|
|
|
|
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
|
2010-10-18 14:12:27 +02:00
|
|
|
|
--echo #
|
|
|
|
|
--echo # Bug#56814 Explain + subselect + fulltext crashes server
|
|
|
|
|
--echo #
|
|
|
|
|
|
|
|
|
|
CREATE TABLE t1(f1 VARCHAR(6) NOT NULL,
|
|
|
|
|
FULLTEXT KEY(f1),UNIQUE(f1));
|
|
|
|
|
INSERT INTO t1 VALUES ('test');
|
|
|
|
|
|
|
|
|
|
EXPLAIN SELECT 1 FROM t1
|
2011-12-19 22:05:44 +01:00
|
|
|
|
WHERE 1 > ALL((SELECT t1.f1 FROM t1 JOIN t1 a ON (MATCH(t1.f1) AGAINST (""))
|
2010-10-18 14:12:27 +02:00
|
|
|
|
WHERE t1.f1 GROUP BY t1.f1));
|
|
|
|
|
|
|
|
|
|
PREPARE stmt FROM
|
|
|
|
|
'EXPLAIN SELECT 1 FROM t1
|
2011-12-19 22:05:44 +01:00
|
|
|
|
WHERE 1 > ALL((SELECT t1.f1 FROM t1 RIGHT OUTER JOIN t1 a
|
2010-10-18 14:12:27 +02:00
|
|
|
|
ON (MATCH(t1.f1) AGAINST (""))
|
|
|
|
|
WHERE t1.f1 GROUP BY t1.f1))';
|
|
|
|
|
|
|
|
|
|
EXECUTE stmt;
|
|
|
|
|
EXECUTE stmt;
|
|
|
|
|
|
|
|
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
|
|
|
|
|
|
PREPARE stmt FROM
|
|
|
|
|
'EXPLAIN SELECT 1 FROM t1
|
2011-12-19 22:05:44 +01:00
|
|
|
|
WHERE 1 > ALL((SELECT t1.f1 FROM t1 JOIN t1 a
|
2010-10-18 14:12:27 +02:00
|
|
|
|
ON (MATCH(t1.f1) AGAINST (""))
|
|
|
|
|
WHERE t1.f1 GROUP BY t1.f1))';
|
|
|
|
|
|
|
|
|
|
EXECUTE stmt;
|
|
|
|
|
EXECUTE stmt;
|
|
|
|
|
|
|
|
|
|
DEALLOCATE PREPARE stmt;
|
|
|
|
|
|
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
|
2009-03-11 13:29:59 +01:00
|
|
|
|
--echo End of 5.1 tests.
|
2011-03-24 11:27:11 +01:00
|
|
|
|
|
|
|
|
|
--echo #
|
|
|
|
|
--echo # Bug#11829785 EXPLAIN EXTENDED CRASH WITH RIGHT OUTER JOIN, SUBQUERIES
|
|
|
|
|
--echo #
|
|
|
|
|
|
|
|
|
|
CREATE TABLE t1(a INT);
|
|
|
|
|
|
|
|
|
|
INSERT INTO t1 VALUES (0), (0);
|
|
|
|
|
|
|
|
|
|
PREPARE s FROM
|
|
|
|
|
'EXPLAIN EXTENDED
|
|
|
|
|
SELECT SUBSTRING(1, (SELECT 1 FROM t1 a1 RIGHT OUTER JOIN t1 ON 0)) AS d
|
|
|
|
|
FROM t1 WHERE 0 > ANY (SELECT @a FROM t1)';
|
|
|
|
|
|
|
|
|
|
--error ER_SUBQUERY_NO_1_ROW
|
|
|
|
|
EXECUTE s;
|
|
|
|
|
|
|
|
|
|
DEALLOCATE PREPARE s;
|
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
|
|
|
|
|
--echo #
|
2011-05-05 03:08:44 +02:00
|
|
|
|
--echo # Bug#776295: EXPLAIN EXTENDED with always false multiple equality
|
|
|
|
|
--echo # in the WHERE condition of a derived table
|
|
|
|
|
--echo #
|
|
|
|
|
|
|
|
|
|
CREATE TABLE t1 (a int) ;
|
|
|
|
|
|
|
|
|
|
CREATE TABLE t2 (a int) ;
|
|
|
|
|
INSERT INTO t2 VALUES (8);
|
|
|
|
|
|
2011-11-26 23:23:00 +01:00
|
|
|
|
set @tmp_optimizer_switch=@@optimizer_switch;
|
|
|
|
|
set optimizer_switch='derived_merge=off,derived_with_keys=off';
|
2011-05-05 03:08:44 +02:00
|
|
|
|
EXPLAIN EXTENDED
|
|
|
|
|
SELECT * FROM ( SELECT t1.a FROM t1,t2 WHERE t2.a = t1.a ) AS t;
|
2011-11-26 23:23:00 +01:00
|
|
|
|
set optimizer_switch=@tmp_optimizer_switch;
|
2011-05-05 03:08:44 +02:00
|
|
|
|
|
|
|
|
|
DROP TABLE t1,t2;
|
2015-12-10 13:36:58 +01:00
|
|
|
|
|
|
|
|
|
--echo #
|
|
|
|
|
--echo # MDEV-7215: EXPLAIN REPLACE produces an error:
|
|
|
|
|
--echo # Column count doesn't match value count
|
|
|
|
|
--echo #
|
|
|
|
|
create table t1 (a int);
|
|
|
|
|
insert into t1 values (1);
|
|
|
|
|
create table t2 (b int, c int);
|
|
|
|
|
|
|
|
|
|
replace into t2 select 100, (select a from t1);
|
|
|
|
|
explain replace into t2 select 100, (select a from t1);
|
|
|
|
|
#analyze replace into t2 select 100, (select a from t1);
|
|
|
|
|
|
|
|
|
|
drop table t1, t2;
|
|
|
|
|
|
|
|
|
|
--echo # End of 10.1 tests
|