2001-09-28 07:05:54 +02:00
|
|
|
|
drop table if exists t1;
|
|
|
|
|
create table t1 (id int not null, str char(10), unique(str));
|
2003-01-20 17:17:14 +01:00
|
|
|
|
explain select * from t1;
|
2003-01-21 20:07:59 +01:00
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
|
1 SIMPLE t1 system NULL NULL NULL NULL 0 const row not found
|
2001-09-28 07:05:54 +02:00
|
|
|
|
insert into t1 values (1, null),(2, null),(3, "foo"),(4, "bar");
|
|
|
|
|
select * from t1 where str is null;
|
2000-12-28 02:56:38 +01:00
|
|
|
|
id str
|
|
|
|
|
1 NULL
|
|
|
|
|
2 NULL
|
2001-09-28 07:05:54 +02:00
|
|
|
|
select * from t1 where str="foo";
|
2000-12-28 02:56:38 +01:00
|
|
|
|
id str
|
|
|
|
|
3 foo
|
2001-09-28 07:05:54 +02:00
|
|
|
|
explain select * from t1 where str is null;
|
2002-09-26 22:08:22 +02:00
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
2002-11-21 14:56:48 +01:00
|
|
|
|
1 SIMPLE t1 ref str str 11 const 1 Using where
|
2001-09-28 07:05:54 +02:00
|
|
|
|
explain select * from t1 where str="foo";
|
2002-09-26 22:08:22 +02:00
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
2002-10-03 17:47:04 +02:00
|
|
|
|
1 SIMPLE t1 const str str 11 const 1
|
2001-09-28 07:05:54 +02:00
|
|
|
|
explain select * from t1 ignore key (str) where str="foo";
|
2002-09-26 22:08:22 +02:00
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
2002-11-21 14:56:48 +01:00
|
|
|
|
1 SIMPLE t1 ALL NULL NULL NULL NULL 4 Using where
|
2001-09-28 07:05:54 +02:00
|
|
|
|
explain select * from t1 use key (str,str) where str="foo";
|
2002-09-26 22:08:22 +02:00
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
2002-10-03 17:47:04 +02:00
|
|
|
|
1 SIMPLE t1 const str str 11 const 1
|
2001-09-28 07:05:54 +02: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 HY000: Key 'foo' doesn't exist in table 't1'
|
2001-09-28 07:05:54 +02:00
|
|
|
|
explain select * from t1 ignore 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 HY000: Key 'foo' doesn't exist in table 't1'
|
2001-09-28 07:05:54 +02:00
|
|
|
|
drop table t1;
|
|
|
|
|
explain select 1;
|
2002-09-26 22:08:22 +02:00
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
2002-12-14 16:43:01 +01:00
|
|
|
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
2003-02-07 16:57:07 +01:00
|
|
|
|
create table t1 (a int not null);
|
|
|
|
|
explain select count(*) from t1;
|
2003-02-08 01:09:21 +01:00
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL Select tables optimized away
|
2003-02-07 16:57:07 +01:00
|
|
|
|
insert into t1 values(1);
|
|
|
|
|
explain select count(*) from t1;
|
2003-02-08 01:09:21 +01:00
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL Select tables optimized away
|
2003-02-07 16:57:07 +01:00
|
|
|
|
insert into t1 values(1);
|
|
|
|
|
explain select count(*) from t1;
|
2003-02-08 01:09:21 +01:00
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL Select tables optimized away
|
2003-02-07 16:57:07 +01:00
|
|
|
|
drop table t1;
|
2004-05-14 10:08:22 +02:00
|
|
|
|
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;
|
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
|
1 SIMPLE <09><><EFBFBD> ref <09><><EFBFBD>0,<2C><><EFBFBD>01 <09><><EFBFBD>0 5 const 1 Using where; Using index
|
|
|
|
|
drop table <20><><EFBFBD>;
|
|
|
|
|
set names latin1;
|
2006-05-03 16:02:43 +02:00
|
|
|
|
select 3 into @v1;
|
|
|
|
|
explain select 3 into @v1;
|
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL No tables used
|
2007-03-07 19:44:58 +01:00
|
|
|
|
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;
|
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
|
1 SIMPLE t1 system NULL NULL NULL NULL 1
|
|
|
|
|
Warnings:
|
|
|
|
|
Note 1003 select `test`.`t1`.`f1` AS `f1`,`test`.`t1`.`f2` AS `f2` from `test`.`t1` where 1
|
|
|
|
|
explain extended select * from t1 where 0;
|
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL Impossible WHERE
|
|
|
|
|
Warnings:
|
|
|
|
|
Note 1003 select `test`.`t1`.`f1` AS `f1`,`test`.`t1`.`f2` AS `f2` from `test`.`t1` where 0
|
|
|
|
|
explain extended select * from t1 where 1;
|
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
|
1 SIMPLE t1 system NULL NULL NULL NULL 1
|
|
|
|
|
Warnings:
|
|
|
|
|
Note 1003 select `test`.`t1`.`f1` AS `f1`,`test`.`t1`.`f2` AS `f2` from `test`.`t1` where 1
|
|
|
|
|
explain extended select * from t1 having 0;
|
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
|
1 SIMPLE NULL NULL NULL NULL NULL NULL NULL Impossible HAVING
|
|
|
|
|
Warnings:
|
|
|
|
|
Note 1003 select `test`.`t1`.`f1` AS `f1`,`test`.`t1`.`f2` AS `f2` from `test`.`t1` having 0
|
|
|
|
|
explain extended select * from t1 having 1;
|
|
|
|
|
id select_type table type possible_keys key key_len ref rows Extra
|
|
|
|
|
1 SIMPLE t1 system NULL NULL NULL NULL 1
|
|
|
|
|
Warnings:
|
|
|
|
|
Note 1003 select `test`.`t1`.`f1` AS `f1`,`test`.`t1`.`f2` AS `f2` from `test`.`t1` having 1
|
|
|
|
|
drop table t1;
|