13 changed files with 10204 additions and 72 deletions
-
8997mysql-test/include/dbt3_s001.inc
-
566mysql-test/r/innodb_ext_key.result
-
36mysql-test/r/optimizer_switch.result
-
294mysql-test/t/innodb_ext_key.test
-
3sql/mysql_priv.h
-
8sql/mysqld.cc
-
38sql/opt_range.cc
-
4sql/opt_sum.cc
-
27sql/sql_select.cc
-
3sql/structs.h
-
238sql/table.cc
-
11sql/table.h
-
51storage/xtradb/handler/ha_innodb.cc
8997
mysql-test/include/dbt3_s001.inc
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -0,0 +1,566 @@ |
|||
DROP TABLE IF EXISTS t1,t2,t3,t4; |
|||
DROP DATABASE IF EXISTS dbt3_s001; |
|||
SET SESSION STORAGE_ENGINE='InnoDB'; |
|||
CREATE DATABASE dbt3_s001; |
|||
use dbt3_s001; |
|||
set @save_ext_key_optimizer_switch=@@optimizer_switch; |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select count(*) from lineitem where l_orderkey=130 and l_shipdate='1992-07-01'; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem ref PRIMARY,i_l_shipdate,i_l_orderkey,i_l_orderkey_quantity PRIMARY 4 const 5 Using where |
|||
flush status; |
|||
select count(*) from lineitem where l_orderkey=130 and l_shipdate='1992-07-01'; |
|||
count(*) |
|||
1 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 5 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select count(*) from lineitem where l_orderkey=130 and l_shipdate='1992-07-01'; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem ref PRIMARY,i_l_shipdate,i_l_orderkey,i_l_orderkey_quantity i_l_shipdate 8 const,const 1 Using index |
|||
flush status; |
|||
select count(*) from lineitem where l_orderkey=130 and l_shipdate='1992-07-01'; |
|||
count(*) |
|||
1 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 1 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select count(*) from lineitem |
|||
where l_orderkey=130 and l_linenumber=2 and l_shipdate='1992-07-01'; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem const PRIMARY,i_l_shipdate,i_l_orderkey,i_l_orderkey_quantity PRIMARY 8 const,const 1 |
|||
flush status; |
|||
select count(*) from lineitem |
|||
where l_orderkey=130 and l_linenumber=2 and l_shipdate='1992-07-01'; |
|||
count(*) |
|||
1 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 0 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select count(*) from lineitem |
|||
where l_orderkey=130 and l_linenumber=2 and l_shipdate='1992-07-01'; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem const PRIMARY,i_l_shipdate,i_l_orderkey,i_l_orderkey_quantity i_l_shipdate 12 const,const,const 1 Using index |
|||
flush status; |
|||
select count(*) from lineitem |
|||
where l_orderkey=130 and l_linenumber=2 and l_shipdate='1992-07-01'; |
|||
count(*) |
|||
1 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 0 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select count(*) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem ref PRIMARY,i_l_shipdate,i_l_orderkey,i_l_orderkey_quantity i_l_shipdate 4 const 6 Using where; Using index |
|||
flush status; |
|||
select count(*) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000; |
|||
count(*) |
|||
1 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 6 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select count(*) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem range PRIMARY,i_l_shipdate,i_l_orderkey,i_l_orderkey_quantity i_l_shipdate 8 NULL 1 Using where; Using index |
|||
flush status; |
|||
select count(*) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000; |
|||
count(*) |
|||
1 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 1 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem ref PRIMARY,i_l_shipdate,i_l_orderkey,i_l_orderkey_quantity i_l_shipdate 4 const 6 Using where; Using index |
|||
flush status; |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
l_orderkey l_linenumber |
|||
1088 3 |
|||
1217 1 |
|||
1221 3 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 6 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem range PRIMARY,i_l_shipdate,i_l_orderkey,i_l_orderkey_quantity i_l_shipdate 8 NULL 3 Using where; Using index |
|||
flush status; |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
l_orderkey l_linenumber |
|||
1088 3 |
|||
1217 1 |
|||
1221 3 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 3 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select min(l_orderkey) from lineitem where l_shipdate='1992-07-01'; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem ref i_l_shipdate i_l_shipdate 4 const 6 Using index |
|||
flush status; |
|||
select min(l_orderkey) from lineitem where l_shipdate='1992-07-01'; |
|||
min(l_orderkey) |
|||
130 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 6 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select min(l_orderkey) from lineitem where l_shipdate='1992-07-01'; |
|||
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 |
|||
flush status; |
|||
select min(l_orderkey) from lineitem where l_shipdate='1992-07-01'; |
|||
min(l_orderkey) |
|||
130 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 0 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select min(l_orderkey) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem ref PRIMARY,i_l_shipdate,i_l_orderkey,i_l_orderkey_quantity i_l_shipdate 4 const 6 Using where; Using index |
|||
flush status; |
|||
select min(l_orderkey) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
min(l_orderkey) |
|||
1088 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 6 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select min(l_orderkey) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
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 |
|||
flush status; |
|||
select min(l_orderkey) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
min(l_orderkey) |
|||
1088 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 0 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select max(l_linenumber) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey=130; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem ref PRIMARY,i_l_shipdate,i_l_orderkey,i_l_orderkey_quantity PRIMARY 4 const 5 Using where |
|||
flush status; |
|||
select max(l_linenumber) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey=130; |
|||
max(l_linenumber) |
|||
2 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 5 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select max(l_linenumber) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey=130; |
|||
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 |
|||
flush status; |
|||
select max(l_linenumber) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey=130; |
|||
max(l_linenumber) |
|||
2 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 0 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey=130 |
|||
or l_receiptdate='1992-07-01' and l_orderkey=5603; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem index_merge i_l_shipdate,i_l_receiptdate i_l_shipdate,i_l_receiptdate 4,4 NULL 9 Using union(i_l_shipdate,i_l_receiptdate); Using where |
|||
flush status; |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey=130 |
|||
or l_receiptdate='1992-07-01' and l_orderkey=5603; |
|||
l_orderkey l_linenumber |
|||
130 2 |
|||
5603 2 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 2 |
|||
Handler_read_next 9 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 9 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey=130 |
|||
or l_receiptdate='1992-07-01' and l_orderkey=5603; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem index_merge i_l_shipdate,i_l_receiptdate i_l_shipdate,i_l_receiptdate 8,8 NULL 2 Using sort_union(i_l_shipdate,i_l_receiptdate); Using where |
|||
flush status; |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey=130 |
|||
or l_receiptdate='1992-07-01' and l_orderkey=5603; |
|||
l_orderkey l_linenumber |
|||
130 2 |
|||
5603 2 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 2 |
|||
Handler_read_next 2 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 2 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem index_merge i_l_shipdate,i_l_receiptdate i_l_shipdate,i_l_receiptdate 4,4 NULL 9 Using union(i_l_shipdate,i_l_receiptdate); Using where |
|||
flush status; |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
l_orderkey l_linenumber |
|||
130 2 |
|||
5603 2 |
|||
5959 3 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 2 |
|||
Handler_read_next 9 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 9 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem index_merge i_l_shipdate,i_l_receiptdate i_l_shipdate,i_l_receiptdate 8,8 NULL 3 Using sort_union(i_l_shipdate,i_l_receiptdate); Using where |
|||
flush status; |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
l_orderkey l_linenumber |
|||
130 2 |
|||
5603 2 |
|||
5959 3 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 2 |
|||
Handler_read_next 3 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 3 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem index_merge PRIMARY,i_l_shipdate,i_l_receiptdate,i_l_orderkey,i_l_orderkey_quantity i_l_shipdate,PRIMARY,i_l_receiptdate,PRIMARY 4,4,4,4 NULL 2 Using union(intersect(i_l_shipdate,PRIMARY),intersect(i_l_receiptdate,PRIMARY)); Using where |
|||
flush status; |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
l_orderkey l_linenumber |
|||
130 2 |
|||
5603 2 |
|||
5959 3 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 2 |
|||
Handler_read_next 9 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 3 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem index_merge PRIMARY,i_l_shipdate,i_l_receiptdate,i_l_orderkey,i_l_orderkey_quantity i_l_shipdate,i_l_receiptdate 8,8 NULL 3 Using sort_union(i_l_shipdate,i_l_receiptdate); Using where |
|||
flush status; |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
l_orderkey l_linenumber |
|||
130 2 |
|||
5603 2 |
|||
5959 3 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 2 |
|||
Handler_read_next 3 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 3 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select max(l_orderkey) from lineitem |
|||
where l_partkey between 1 and 10 group by l_partkey; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem range i_l_suppkey_partkey,i_l_partkey i_l_partkey 5 NULL # Using where; Using index |
|||
flush status; |
|||
select max(l_orderkey) from lineitem |
|||
where l_partkey between 1 and 10 group by l_partkey; |
|||
max(l_orderkey) |
|||
5984 |
|||
5957 |
|||
5892 |
|||
5856 |
|||
5959 |
|||
5957 |
|||
5794 |
|||
5894 |
|||
5859 |
|||
5632 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 1 |
|||
Handler_read_next 294 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select max(l_orderkey) from lineitem |
|||
where l_partkey between 1 and 10 group by l_partkey; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem range i_l_suppkey_partkey,i_l_partkey i_l_partkey 5 NULL # Using where; Using index for group-by |
|||
flush status; |
|||
select max(l_orderkey) from lineitem |
|||
where l_partkey between 1 and 10 group by l_partkey; |
|||
max(l_orderkey) |
|||
5984 |
|||
5957 |
|||
5892 |
|||
5856 |
|||
5959 |
|||
5957 |
|||
5794 |
|||
5894 |
|||
5859 |
|||
5632 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 21 |
|||
Handler_read_next 0 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select max(l_orderkey) from lineitem |
|||
where l_suppkey in (1,4) group by l_suppkey; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem range i_l_suppkey i_l_suppkey 5 NULL # Using where; Using index |
|||
flush status; |
|||
select max(l_orderkey) from lineitem |
|||
where l_suppkey in (1,4) group by l_suppkey; |
|||
max(l_orderkey) |
|||
5988 |
|||
5984 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 2 |
|||
Handler_read_next 1230 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select max(l_orderkey) from lineitem |
|||
where l_suppkey in (1,4) group by l_suppkey; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE lineitem range i_l_suppkey i_l_suppkey 5 NULL # Using where; Using index for group-by |
|||
flush status; |
|||
select max(l_orderkey) from lineitem |
|||
where l_suppkey in (1,4) group by l_suppkey; |
|||
max(l_orderkey) |
|||
5988 |
|||
5984 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 6 |
|||
Handler_read_next 0 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
create index i_p_retailprice on part(p_retailprice); |
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select o_orderkey, p_partkey |
|||
from part use index (i_p_retailprice), |
|||
lineitem use index (i_l_partkey), orders |
|||
where p_retailprice > 1100 and o_orderdate='1997-01-01' |
|||
and o_orderkey=l_orderkey and p_partkey=l_partkey; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE part range i_p_retailprice i_p_retailprice 9 NULL # Using where; Using index |
|||
1 SIMPLE orders ref PRIMARY,i_o_orderdate i_o_orderdate 4 const # Using index |
|||
1 SIMPLE lineitem ref i_l_partkey i_l_partkey 5 dbt3_s001.part.p_partkey # Using where; Using index |
|||
flush status; |
|||
select o_orderkey, p_partkey |
|||
from part use index (i_p_retailprice), |
|||
lineitem use index (i_l_partkey), orders |
|||
where p_retailprice > 1100 and o_orderdate='1997-01-01' |
|||
and o_orderkey=l_orderkey and p_partkey=l_partkey; |
|||
o_orderkey p_partkey |
|||
5895 200 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 3 |
|||
Handler_read_next 26 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select o_orderkey, p_partkey |
|||
from part use index (i_p_retailprice), |
|||
lineitem use index (i_l_partkey), orders |
|||
where p_retailprice > 1100 and o_orderdate='1997-01-01' |
|||
and o_orderkey=l_orderkey and p_partkey=l_partkey; |
|||
id select_type table type possible_keys key key_len ref rows Extra |
|||
1 SIMPLE part range i_p_retailprice i_p_retailprice 9 NULL # Using where; Using index |
|||
1 SIMPLE orders ref PRIMARY,i_o_orderdate i_o_orderdate 4 const # Using index |
|||
1 SIMPLE lineitem ref i_l_partkey i_l_partkey 9 dbt3_s001.part.p_partkey,dbt3_s001.orders.o_orderkey # Using index |
|||
flush status; |
|||
select o_orderkey, p_partkey |
|||
from part use index (i_p_retailprice), |
|||
lineitem use index (i_l_partkey), orders |
|||
where p_retailprice > 1100 and o_orderdate='1997-01-01' |
|||
and o_orderkey=l_orderkey and p_partkey=l_partkey; |
|||
o_orderkey p_partkey |
|||
5895 200 |
|||
show status like 'handler_read%'; |
|||
Variable_name Value |
|||
Handler_read_first 0 |
|||
Handler_read_key 3 |
|||
Handler_read_next 3 |
|||
Handler_read_prev 0 |
|||
Handler_read_rnd 0 |
|||
Handler_read_rnd_next 0 |
|||
set optimizer_switch=@save_ext_key_optimizer_switch; |
|||
DROP DATABASE dbt3_s001; |
|||
SET SESSION STORAGE_ENGINE=DEFAULT; |
|||
@ -0,0 +1,294 @@ |
|||
--source include/have_innodb.inc |
|||
|
|||
--disable_warnings |
|||
DROP TABLE IF EXISTS t1,t2,t3,t4; |
|||
DROP DATABASE IF EXISTS dbt3_s001; |
|||
--enable_warnings |
|||
|
|||
SET SESSION STORAGE_ENGINE='InnoDB'; |
|||
|
|||
CREATE DATABASE dbt3_s001; |
|||
|
|||
use dbt3_s001; |
|||
|
|||
--disable_query_log |
|||
--disable_result_log |
|||
--disable_warnings |
|||
--source include/dbt3_s001.inc |
|||
--enable_warnings |
|||
--enable_result_log |
|||
--enable_query_log |
|||
|
|||
set @save_ext_key_optimizer_switch=@@optimizer_switch; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select count(*) from lineitem where l_orderkey=130 and l_shipdate='1992-07-01'; |
|||
flush status; |
|||
select count(*) from lineitem where l_orderkey=130 and l_shipdate='1992-07-01'; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select count(*) from lineitem where l_orderkey=130 and l_shipdate='1992-07-01'; |
|||
flush status; |
|||
select count(*) from lineitem where l_orderkey=130 and l_shipdate='1992-07-01'; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select count(*) from lineitem |
|||
where l_orderkey=130 and l_linenumber=2 and l_shipdate='1992-07-01'; |
|||
flush status; |
|||
select count(*) from lineitem |
|||
where l_orderkey=130 and l_linenumber=2 and l_shipdate='1992-07-01'; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select count(*) from lineitem |
|||
where l_orderkey=130 and l_linenumber=2 and l_shipdate='1992-07-01'; |
|||
flush status; |
|||
select count(*) from lineitem |
|||
where l_orderkey=130 and l_linenumber=2 and l_shipdate='1992-07-01'; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select count(*) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000; |
|||
flush status; |
|||
select count(*) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select count(*) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000; |
|||
flush status; |
|||
select count(*) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
flush status; |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
flush status; |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select min(l_orderkey) from lineitem where l_shipdate='1992-07-01'; |
|||
flush status; |
|||
select min(l_orderkey) from lineitem where l_shipdate='1992-07-01'; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select min(l_orderkey) from lineitem where l_shipdate='1992-07-01'; |
|||
flush status; |
|||
select min(l_orderkey) from lineitem where l_shipdate='1992-07-01'; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select min(l_orderkey) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
flush status; |
|||
select min(l_orderkey) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select min(l_orderkey) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
flush status; |
|||
select min(l_orderkey) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1001 and 2000; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select max(l_linenumber) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey=130; |
|||
flush status; |
|||
select max(l_linenumber) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey=130; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select max(l_linenumber) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey=130; |
|||
flush status; |
|||
select max(l_linenumber) from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey=130; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey=130 |
|||
or l_receiptdate='1992-07-01' and l_orderkey=5603; |
|||
flush status; |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey=130 |
|||
or l_receiptdate='1992-07-01' and l_orderkey=5603; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey=130 |
|||
or l_receiptdate='1992-07-01' and l_orderkey=5603; |
|||
flush status; |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey=130 |
|||
or l_receiptdate='1992-07-01' and l_orderkey=5603; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
flush status; |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
flush status; |
|||
select l_orderkey, l_linenumber |
|||
from lineitem use index (i_l_shipdate, i_l_receiptdate) |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
explain |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
flush status; |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
explain |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
flush status; |
|||
select l_orderkey, l_linenumber from lineitem |
|||
where l_shipdate='1992-07-01' and l_orderkey between 1 and 1000 |
|||
or l_receiptdate='1992-07-01' and l_orderkey between 5001 and 6000; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
--replace_column 9 # |
|||
explain |
|||
select max(l_orderkey) from lineitem |
|||
where l_partkey between 1 and 10 group by l_partkey; |
|||
flush status; |
|||
select max(l_orderkey) from lineitem |
|||
where l_partkey between 1 and 10 group by l_partkey; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
--replace_column 9 # |
|||
explain |
|||
select max(l_orderkey) from lineitem |
|||
where l_partkey between 1 and 10 group by l_partkey; |
|||
flush status; |
|||
select max(l_orderkey) from lineitem |
|||
where l_partkey between 1 and 10 group by l_partkey; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
--replace_column 9 # |
|||
explain |
|||
select max(l_orderkey) from lineitem |
|||
where l_suppkey in (1,4) group by l_suppkey; |
|||
flush status; |
|||
select max(l_orderkey) from lineitem |
|||
where l_suppkey in (1,4) group by l_suppkey; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
--replace_column 9 # |
|||
explain |
|||
select max(l_orderkey) from lineitem |
|||
where l_suppkey in (1,4) group by l_suppkey; |
|||
flush status; |
|||
select max(l_orderkey) from lineitem |
|||
where l_suppkey in (1,4) group by l_suppkey; |
|||
show status like 'handler_read%'; |
|||
|
|||
create index i_p_retailprice on part(p_retailprice); |
|||
|
|||
set optimizer_switch='extended_keys=off'; |
|||
--replace_column 9 # |
|||
explain |
|||
select o_orderkey, p_partkey |
|||
from part use index (i_p_retailprice), |
|||
lineitem use index (i_l_partkey), orders |
|||
where p_retailprice > 1100 and o_orderdate='1997-01-01' |
|||
and o_orderkey=l_orderkey and p_partkey=l_partkey; |
|||
flush status; |
|||
select o_orderkey, p_partkey |
|||
from part use index (i_p_retailprice), |
|||
lineitem use index (i_l_partkey), orders |
|||
where p_retailprice > 1100 and o_orderdate='1997-01-01' |
|||
and o_orderkey=l_orderkey and p_partkey=l_partkey; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch='extended_keys=on'; |
|||
--replace_column 9 # |
|||
explain |
|||
select o_orderkey, p_partkey |
|||
from part use index (i_p_retailprice), |
|||
lineitem use index (i_l_partkey), orders |
|||
where p_retailprice > 1100 and o_orderdate='1997-01-01' |
|||
and o_orderkey=l_orderkey and p_partkey=l_partkey; |
|||
flush status; |
|||
select o_orderkey, p_partkey |
|||
from part use index (i_p_retailprice), |
|||
lineitem use index (i_l_partkey), orders |
|||
where p_retailprice > 1100 and o_orderdate='1997-01-01' |
|||
and o_orderkey=l_orderkey and p_partkey=l_partkey; |
|||
show status like 'handler_read%'; |
|||
|
|||
set optimizer_switch=@save_ext_key_optimizer_switch; |
|||
|
|||
DROP DATABASE dbt3_s001; |
|||
|
|||
SET SESSION STORAGE_ENGINE=DEFAULT; |
|||
Write
Preview
Loading…
Cancel
Save
Reference in new issue