mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 04:22:27 +01:00
567 lines
19 KiB
Text
567 lines
19 KiB
Text
|
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;
|