mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-26 16:38:11 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			3864 lines
		
	
	
	
		
			124 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			3864 lines
		
	
	
	
		
			124 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
| DROP DATABASE IF EXISTS dbt3_s001;
 | |
| CREATE DATABASE dbt3_s001 CHARACTER SET latin1;
 | |
| use dbt3_s001;
 | |
| create index i_n_name on nation(n_name);
 | |
| analyze table
 | |
| nation, lineitem, customer, orders, part, supplier, partsupp, region
 | |
| persistent for all;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| dbt3_s001.nation	analyze	status	Engine-independent statistics collected
 | |
| dbt3_s001.nation	analyze	status	OK
 | |
| dbt3_s001.lineitem	analyze	status	Engine-independent statistics collected
 | |
| dbt3_s001.lineitem	analyze	status	OK
 | |
| dbt3_s001.customer	analyze	status	Engine-independent statistics collected
 | |
| dbt3_s001.customer	analyze	status	OK
 | |
| dbt3_s001.orders	analyze	status	Engine-independent statistics collected
 | |
| dbt3_s001.orders	analyze	status	OK
 | |
| dbt3_s001.part	analyze	status	Engine-independent statistics collected
 | |
| dbt3_s001.part	analyze	status	OK
 | |
| dbt3_s001.supplier	analyze	status	Engine-independent statistics collected
 | |
| dbt3_s001.supplier	analyze	status	OK
 | |
| dbt3_s001.partsupp	analyze	status	Engine-independent statistics collected
 | |
| dbt3_s001.partsupp	analyze	status	OK
 | |
| dbt3_s001.region	analyze	status	Engine-independent statistics collected
 | |
| dbt3_s001.region	analyze	status	OK
 | |
| # Pullout
 | |
| # =======
 | |
| explain
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	customer	ref	PRIMARY,i_c_nationkey	i_c_nationkey	5	dbt3_s001.nation.n_nationkey	6	
 | |
| 1	PRIMARY	orders	ref|filter	i_o_orderdate,i_o_custkey	i_o_custkey|i_o_orderdate	5|4	dbt3_s001.customer.c_custkey	15 (7%)	Using where; Using rowid filter
 | |
| explain format=json
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": 0.052271677,
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "nation",
 | |
|           "access_type": "ref",
 | |
|           "possible_keys": ["PRIMARY", "i_n_name"],
 | |
|           "key": "i_n_name",
 | |
|           "key_length": "26",
 | |
|           "used_key_parts": ["n_name"],
 | |
|           "ref": ["const"],
 | |
|           "loops": 1,
 | |
|           "rows": 1,
 | |
|           "cost": 0.002024411,
 | |
|           "filtered": 100,
 | |
|           "index_condition": "nation.n_name = 'PERU'"
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "customer",
 | |
|           "access_type": "ref",
 | |
|           "possible_keys": ["PRIMARY", "i_c_nationkey"],
 | |
|           "key": "i_c_nationkey",
 | |
|           "key_length": "5",
 | |
|           "used_key_parts": ["c_nationkey"],
 | |
|           "ref": ["dbt3_s001.nation.n_nationkey"],
 | |
|           "loops": 1,
 | |
|           "rows": 6,
 | |
|           "cost": 0.008193756,
 | |
|           "filtered": 100
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "orders",
 | |
|           "access_type": "ref",
 | |
|           "possible_keys": ["i_o_orderdate", "i_o_custkey"],
 | |
|           "key": "i_o_custkey",
 | |
|           "key_length": "5",
 | |
|           "used_key_parts": ["o_custkey"],
 | |
|           "ref": ["dbt3_s001.customer.c_custkey"],
 | |
|           "rowid_filter": {
 | |
|             "range": {
 | |
|               "key": "i_o_orderdate",
 | |
|               "used_key_parts": ["o_orderDATE"]
 | |
|             },
 | |
|             "rows": 108,
 | |
|             "selectivity_pct": 7.2
 | |
|           },
 | |
|           "loops": 6,
 | |
|           "rows": 15,
 | |
|           "cost": 0.04205351,
 | |
|           "filtered": 7.199999809,
 | |
|           "attached_condition": "orders.o_orderDATE between '1992-01-01' and '1992-06-30'"
 | |
|         }
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| o_orderkey	o_totalprice
 | |
| 644	201268.06
 | |
| 2880	145761.99
 | |
| 3142	16030.15
 | |
| 5382	138423.03
 | |
| 5095	184583.99
 | |
| 737	12984.85
 | |
| 1729	12137.76
 | |
| 5121	150334.57
 | |
| explain
 | |
| update orders set o_totalprice = o_totalprice-50 where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	customer	ref	PRIMARY,i_c_nationkey	i_c_nationkey	5	dbt3_s001.nation.n_nationkey	6	
 | |
| 1	PRIMARY	orders	ref|filter	i_o_orderdate,i_o_custkey	i_o_custkey|i_o_orderdate	5|4	dbt3_s001.customer.c_custkey	15 (7%)	Using where; Using rowid filter
 | |
| explain format=json
 | |
| update orders set o_totalprice = o_totalprice-50 where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": "COST_REPLACED",
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "nation",
 | |
|           "access_type": "ref",
 | |
|           "possible_keys": ["PRIMARY", "i_n_name"],
 | |
|           "key": "i_n_name",
 | |
|           "key_length": "26",
 | |
|           "used_key_parts": ["n_name"],
 | |
|           "ref": ["const"],
 | |
|           "loops": 1,
 | |
|           "rows": 1,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 100,
 | |
|           "index_condition": "nation.n_name = 'PERU'"
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "customer",
 | |
|           "access_type": "ref",
 | |
|           "possible_keys": ["PRIMARY", "i_c_nationkey"],
 | |
|           "key": "i_c_nationkey",
 | |
|           "key_length": "5",
 | |
|           "used_key_parts": ["c_nationkey"],
 | |
|           "ref": ["dbt3_s001.nation.n_nationkey"],
 | |
|           "loops": 1,
 | |
|           "rows": 6,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 100
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "orders",
 | |
|           "access_type": "ref",
 | |
|           "possible_keys": ["i_o_orderdate", "i_o_custkey"],
 | |
|           "key": "i_o_custkey",
 | |
|           "key_length": "5",
 | |
|           "used_key_parts": ["o_custkey"],
 | |
|           "ref": ["dbt3_s001.customer.c_custkey"],
 | |
|           "rowid_filter": {
 | |
|             "range": {
 | |
|               "key": "i_o_orderdate",
 | |
|               "used_key_parts": ["o_orderDATE"]
 | |
|             },
 | |
|             "rows": 108,
 | |
|             "selectivity_pct": 7.2
 | |
|           },
 | |
|           "loops": 6,
 | |
|           "rows": 15,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 7.199999809,
 | |
|           "attached_condition": "orders.o_orderDATE between '1992-01-01' and '1992-06-30'"
 | |
|         }
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| update orders set o_totalprice = o_totalprice-50 where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| o_orderkey	o_totalprice
 | |
| 644	201218.06
 | |
| 2880	145711.99
 | |
| 3142	15980.15
 | |
| 5382	138373.03
 | |
| 5095	184533.99
 | |
| 737	12934.85
 | |
| 1729	12087.76
 | |
| 5121	150284.57
 | |
| update orders set o_totalprice= o_totalprice+50 where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| o_orderkey	o_totalprice
 | |
| 644	201268.06
 | |
| 2880	145761.99
 | |
| 3142	16030.15
 | |
| 5382	138423.03
 | |
| 5095	184583.99
 | |
| 737	12984.85
 | |
| 1729	12137.76
 | |
| 5121	150334.57
 | |
| explain
 | |
| select ps_partkey, ps_suppkey, ps_supplycost from partsupp where (ps_partkey, ps_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 910 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	supplier	ref	PRIMARY,i_s_nationkey	i_s_nationkey	5	dbt3_s001.nation.n_nationkey	1	
 | |
| 1	PRIMARY	part	ALL	PRIMARY	NULL	NULL	NULL	200	Using where; Using join buffer (flat, BNL join)
 | |
| 1	PRIMARY	partsupp	eq_ref	PRIMARY,i_ps_partkey,i_ps_suppkey	PRIMARY	8	dbt3_s001.part.p_partkey,dbt3_s001.supplier.s_suppkey	1	
 | |
| select ps_partkey, ps_suppkey, ps_supplycost from partsupp where (ps_partkey, ps_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 910 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| ps_partkey	ps_suppkey	ps_supplycost
 | |
| 1	8	357.84
 | |
| 3	8	645.4
 | |
| 4	1	444.37
 | |
| 5	8	50.52
 | |
| 6	1	642.13
 | |
| 7	8	763.98
 | |
| 8	1	957.34
 | |
| explain
 | |
| update partsupp set ps_supplycost = ps_supplycost+2 where (ps_partkey, ps_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 910 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	supplier	ref	PRIMARY,i_s_nationkey	i_s_nationkey	5	dbt3_s001.nation.n_nationkey	1	
 | |
| 1	PRIMARY	part	ALL	PRIMARY	NULL	NULL	NULL	200	Using where
 | |
| 1	PRIMARY	partsupp	eq_ref	PRIMARY,i_ps_partkey,i_ps_suppkey	PRIMARY	8	dbt3_s001.part.p_partkey,dbt3_s001.supplier.s_suppkey	1	
 | |
| update partsupp set ps_supplycost = ps_supplycost+2 where (ps_partkey, ps_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 910 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| select ps_partkey, ps_suppkey, ps_supplycost from partsupp where (ps_partkey, ps_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 910 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| ps_partkey	ps_suppkey	ps_supplycost
 | |
| 1	8	359.84
 | |
| 3	8	647.4
 | |
| 4	1	446.37
 | |
| 5	8	52.52
 | |
| 6	1	644.13
 | |
| 7	8	765.98
 | |
| 8	1	959.34
 | |
| update partsupp set ps_supplycost = ps_supplycost-2 where (ps_partkey, ps_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 910 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| select ps_partkey, ps_suppkey, ps_supplycost from partsupp where (ps_partkey, ps_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 910 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| ps_partkey	ps_suppkey	ps_supplycost
 | |
| 1	8	357.84
 | |
| 3	8	645.4
 | |
| 4	1	444.37
 | |
| 5	8	50.52
 | |
| 6	1	642.13
 | |
| 7	8	763.98
 | |
| 8	1	957.34
 | |
| explain
 | |
| select ps_partkey, ps_suppkey, ps_supplycost from partsupp where ps_partkey in (select p_partkey from part
 | |
| where p_retailprice between 901 and 910) and
 | |
| ps_suppkey in (select s_suppkey from supplier
 | |
| where s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	supplier	ref	PRIMARY,i_s_nationkey	i_s_nationkey	5	dbt3_s001.nation.n_nationkey	1	
 | |
| 1	PRIMARY	part	ALL	PRIMARY	NULL	NULL	NULL	200	Using where; Using join buffer (flat, BNL join)
 | |
| 1	PRIMARY	partsupp	eq_ref	PRIMARY,i_ps_partkey,i_ps_suppkey	PRIMARY	8	dbt3_s001.part.p_partkey,dbt3_s001.supplier.s_suppkey	1	
 | |
| select ps_partkey, ps_suppkey, ps_supplycost from partsupp where ps_partkey in (select p_partkey from part
 | |
| where p_retailprice between 901 and 910) and
 | |
| ps_suppkey in (select s_suppkey from supplier
 | |
| where s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| ps_partkey	ps_suppkey	ps_supplycost
 | |
| 1	8	357.84
 | |
| 3	8	645.4
 | |
| 4	1	444.37
 | |
| 5	8	50.52
 | |
| 6	1	642.13
 | |
| 7	8	763.98
 | |
| 8	1	957.34
 | |
| explain
 | |
| update partsupp set ps_supplycost = ps_supplycost+10 where ps_partkey in (select p_partkey from part
 | |
| where p_retailprice between 901 and 910) and
 | |
| ps_suppkey in (select s_suppkey from supplier
 | |
| where s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	supplier	ref	PRIMARY,i_s_nationkey	i_s_nationkey	5	dbt3_s001.nation.n_nationkey	1	
 | |
| 1	PRIMARY	part	ALL	PRIMARY	NULL	NULL	NULL	200	Using where
 | |
| 1	PRIMARY	partsupp	eq_ref	PRIMARY,i_ps_partkey,i_ps_suppkey	PRIMARY	8	dbt3_s001.part.p_partkey,dbt3_s001.supplier.s_suppkey	1	
 | |
| update partsupp set ps_supplycost = ps_supplycost+10 where ps_partkey in (select p_partkey from part
 | |
| where p_retailprice between 901 and 910) and
 | |
| ps_suppkey in (select s_suppkey from supplier
 | |
| where s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| select ps_partkey, ps_suppkey, ps_supplycost from partsupp where ps_partkey in (select p_partkey from part
 | |
| where p_retailprice between 901 and 910) and
 | |
| ps_suppkey in (select s_suppkey from supplier
 | |
| where s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| ps_partkey	ps_suppkey	ps_supplycost
 | |
| 1	8	367.84
 | |
| 3	8	655.4
 | |
| 4	1	454.37
 | |
| 5	8	60.52
 | |
| 6	1	652.13
 | |
| 7	8	773.98
 | |
| 8	1	967.34
 | |
| update partsupp set ps_supplycost = ps_supplycost-10 where ps_partkey in (select p_partkey from part
 | |
| where p_retailprice between 901 and 910) and
 | |
| ps_suppkey in (select s_suppkey from supplier
 | |
| where s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| select ps_partkey, ps_suppkey, ps_supplycost from partsupp where ps_partkey in (select p_partkey from part
 | |
| where p_retailprice between 901 and 910) and
 | |
| ps_suppkey in (select s_suppkey from supplier
 | |
| where s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| ps_partkey	ps_suppkey	ps_supplycost
 | |
| 1	8	357.84
 | |
| 3	8	645.4
 | |
| 4	1	444.37
 | |
| 5	8	50.52
 | |
| 6	1	642.13
 | |
| 7	8	763.98
 | |
| 8	1	957.34
 | |
| explain
 | |
| select l_orderkey, l_linenumber, l_tax from lineitem where l_orderkey in (select o_orderkey from orders
 | |
| where o_custkey in
 | |
| (select c_custkey from customer
 | |
| where c_nationkey in
 | |
| (select n_nationkey from nation
 | |
| where n_name='PERU'))
 | |
| and
 | |
| o_orderDATE between '1992-06-30' and '1992-12-31')
 | |
| and
 | |
| (l_partkey, l_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 1000 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	supplier	ref	PRIMARY,i_s_nationkey	i_s_nationkey	5	dbt3_s001.nation.n_nationkey	1	
 | |
| 1	PRIMARY	customer	ref	PRIMARY,i_c_nationkey	i_c_nationkey	5	dbt3_s001.nation.n_nationkey	6	
 | |
| 1	PRIMARY	orders	ref|filter	PRIMARY,i_o_orderdate,i_o_custkey	i_o_custkey|i_o_orderdate	5|4	dbt3_s001.customer.c_custkey	15 (7%)	Using where; Using rowid filter
 | |
| 1	PRIMARY	lineitem	ref	PRIMARY,i_l_suppkey_partkey,i_l_partkey,i_l_suppkey,i_l_orderkey,i_l_orderkey_quantity	PRIMARY	4	dbt3_s001.orders.o_orderkey	4	Using where
 | |
| 1	PRIMARY	part	eq_ref	PRIMARY	PRIMARY	4	dbt3_s001.lineitem.l_partkey	1	Using where
 | |
| select l_orderkey, l_linenumber, l_tax from lineitem where l_orderkey in (select o_orderkey from orders
 | |
| where o_custkey in
 | |
| (select c_custkey from customer
 | |
| where c_nationkey in
 | |
| (select n_nationkey from nation
 | |
| where n_name='PERU'))
 | |
| and
 | |
| o_orderDATE between '1992-06-30' and '1992-12-31')
 | |
| and
 | |
| (l_partkey, l_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 1000 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| l_orderkey	l_linenumber	l_tax
 | |
| 4996	1	0.01
 | |
| 933	1	0.04
 | |
| 2500	2	0.02
 | |
| 2500	4	0.02
 | |
| explain
 | |
| update lineitem set l_tax = (l_tax*100+1)/100 where l_orderkey in (select o_orderkey from orders
 | |
| where o_custkey in
 | |
| (select c_custkey from customer
 | |
| where c_nationkey in
 | |
| (select n_nationkey from nation
 | |
| where n_name='PERU'))
 | |
| and
 | |
| o_orderDATE between '1992-06-30' and '1992-12-31')
 | |
| and
 | |
| (l_partkey, l_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 1000 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	supplier	ref	PRIMARY,i_s_nationkey	i_s_nationkey	5	dbt3_s001.nation.n_nationkey	1	
 | |
| 1	PRIMARY	customer	ref	PRIMARY,i_c_nationkey	i_c_nationkey	5	dbt3_s001.nation.n_nationkey	6	
 | |
| 1	PRIMARY	orders	ref|filter	PRIMARY,i_o_orderdate,i_o_custkey	i_o_custkey|i_o_orderdate	5|4	dbt3_s001.customer.c_custkey	15 (7%)	Using where; Using rowid filter
 | |
| 1	PRIMARY	lineitem	ref	PRIMARY,i_l_suppkey_partkey,i_l_partkey,i_l_suppkey,i_l_orderkey,i_l_orderkey_quantity	PRIMARY	4	dbt3_s001.orders.o_orderkey	4	Using where
 | |
| 1	PRIMARY	part	eq_ref	PRIMARY	PRIMARY	4	dbt3_s001.lineitem.l_partkey	1	Using where
 | |
| update lineitem set l_tax = (l_tax*100+1)/100 where l_orderkey in (select o_orderkey from orders
 | |
| where o_custkey in
 | |
| (select c_custkey from customer
 | |
| where c_nationkey in
 | |
| (select n_nationkey from nation
 | |
| where n_name='PERU'))
 | |
| and
 | |
| o_orderDATE between '1992-06-30' and '1992-12-31')
 | |
| and
 | |
| (l_partkey, l_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 1000 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| select l_orderkey, l_linenumber, l_tax from lineitem where l_orderkey in (select o_orderkey from orders
 | |
| where o_custkey in
 | |
| (select c_custkey from customer
 | |
| where c_nationkey in
 | |
| (select n_nationkey from nation
 | |
| where n_name='PERU'))
 | |
| and
 | |
| o_orderDATE between '1992-06-30' and '1992-12-31')
 | |
| and
 | |
| (l_partkey, l_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 1000 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| l_orderkey	l_linenumber	l_tax
 | |
| 4996	1	0.02
 | |
| 933	1	0.05
 | |
| 2500	2	0.03
 | |
| 2500	4	0.03
 | |
| update lineitem set l_tax = (l_tax*100-1)/100 where l_orderkey in (select o_orderkey from orders
 | |
| where o_custkey in
 | |
| (select c_custkey from customer
 | |
| where c_nationkey in
 | |
| (select n_nationkey from nation
 | |
| where n_name='PERU'))
 | |
| and
 | |
| o_orderDATE between '1992-06-30' and '1992-12-31')
 | |
| and
 | |
| (l_partkey, l_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 1000 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| select l_orderkey, l_linenumber, l_tax from lineitem where l_orderkey in (select o_orderkey from orders
 | |
| where o_custkey in
 | |
| (select c_custkey from customer
 | |
| where c_nationkey in
 | |
| (select n_nationkey from nation
 | |
| where n_name='PERU'))
 | |
| and
 | |
| o_orderDATE between '1992-06-30' and '1992-12-31')
 | |
| and
 | |
| (l_partkey, l_suppkey) in
 | |
| (select p_partkey, s_suppkey from part, supplier
 | |
| where p_retailprice between 901 and 1000 and
 | |
| s_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| l_orderkey	l_linenumber	l_tax
 | |
| 4996	1	0.01
 | |
| 933	1	0.04
 | |
| 2500	2	0.02
 | |
| 2500	4	0.02
 | |
| # FirstMatch
 | |
| # ==========
 | |
| set optimizer_switch='materialization=off';
 | |
| explain
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ALL	PRIMARY,i_n_regionkey	NULL	NULL	NULL	25	Using where
 | |
| 1	PRIMARY	customer	ref	PRIMARY,i_c_nationkey	i_c_nationkey	5	dbt3_s001.nation.n_nationkey	6	
 | |
| 1	PRIMARY	orders	ref|filter	i_o_orderdate,i_o_custkey	i_o_custkey|i_o_orderdate	5|4	dbt3_s001.customer.c_custkey	15 (9%)	Using where; FirstMatch(customer); Using rowid filter
 | |
| explain format=json
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": "COST_REPLACED",
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "nation",
 | |
|           "access_type": "ALL",
 | |
|           "possible_keys": ["PRIMARY", "i_n_regionkey"],
 | |
|           "loops": 1,
 | |
|           "rows": 25,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 40,
 | |
|           "attached_condition": "nation.n_regionkey in (1,2)"
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "customer",
 | |
|           "access_type": "ref",
 | |
|           "possible_keys": ["PRIMARY", "i_c_nationkey"],
 | |
|           "key": "i_c_nationkey",
 | |
|           "key_length": "5",
 | |
|           "used_key_parts": ["c_nationkey"],
 | |
|           "ref": ["dbt3_s001.nation.n_nationkey"],
 | |
|           "loops": 10,
 | |
|           "rows": 6,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 100
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "orders",
 | |
|           "access_type": "ref",
 | |
|           "possible_keys": ["i_o_orderdate", "i_o_custkey"],
 | |
|           "key": "i_o_custkey",
 | |
|           "key_length": "5",
 | |
|           "used_key_parts": ["o_custkey"],
 | |
|           "ref": ["dbt3_s001.customer.c_custkey"],
 | |
|           "rowid_filter": {
 | |
|             "range": {
 | |
|               "key": "i_o_orderdate",
 | |
|               "used_key_parts": ["o_orderDATE"]
 | |
|             },
 | |
|             "rows": 140,
 | |
|             "selectivity_pct": 9.333333333
 | |
|           },
 | |
|           "loops": 60,
 | |
|           "rows": 15,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 6.666666508,
 | |
|           "attached_condition": "orders.o_orderDATE between '1992-10-09' and '1993-06-08'",
 | |
|           "first_match": "customer"
 | |
|         }
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000017	6.34
 | |
| Customer#000000047	274.58
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000022	591.98
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000028	1007.18
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000077	1738.87
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000124	1842.49
 | |
| Customer#000000127	9280.71
 | |
| explain
 | |
| update customer set c_acctbal = c_acctbal+10 where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ALL	PRIMARY,i_n_regionkey	NULL	NULL	NULL	25	Using where
 | |
| 1	PRIMARY	customer	ref	PRIMARY,i_c_nationkey	i_c_nationkey	5	dbt3_s001.nation.n_nationkey	6	
 | |
| 1	PRIMARY	orders	ref|filter	i_o_orderdate,i_o_custkey	i_o_custkey|i_o_orderdate	5|4	dbt3_s001.customer.c_custkey	15 (9%)	Using where; FirstMatch(customer); Using rowid filter
 | |
| explain format=json
 | |
| update customer set c_acctbal = c_acctbal+10 where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": "COST_REPLACED",
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "nation",
 | |
|           "access_type": "ALL",
 | |
|           "possible_keys": ["PRIMARY", "i_n_regionkey"],
 | |
|           "loops": 1,
 | |
|           "rows": 25,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 40,
 | |
|           "attached_condition": "nation.n_regionkey in (1,2)"
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "customer",
 | |
|           "access_type": "ref",
 | |
|           "possible_keys": ["PRIMARY", "i_c_nationkey"],
 | |
|           "key": "i_c_nationkey",
 | |
|           "key_length": "5",
 | |
|           "used_key_parts": ["c_nationkey"],
 | |
|           "ref": ["dbt3_s001.nation.n_nationkey"],
 | |
|           "loops": 10,
 | |
|           "rows": 6,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 100
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "orders",
 | |
|           "access_type": "ref",
 | |
|           "possible_keys": ["i_o_orderdate", "i_o_custkey"],
 | |
|           "key": "i_o_custkey",
 | |
|           "key_length": "5",
 | |
|           "used_key_parts": ["o_custkey"],
 | |
|           "ref": ["dbt3_s001.customer.c_custkey"],
 | |
|           "rowid_filter": {
 | |
|             "range": {
 | |
|               "key": "i_o_orderdate",
 | |
|               "used_key_parts": ["o_orderDATE"]
 | |
|             },
 | |
|             "rows": 140,
 | |
|             "selectivity_pct": 9.333333333
 | |
|           },
 | |
|           "loops": 60,
 | |
|           "rows": 15,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 6.666666508,
 | |
|           "attached_condition": "orders.o_orderDATE between '1992-10-09' and '1993-06-08'",
 | |
|           "first_match": "customer"
 | |
|         }
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| update customer set c_acctbal = c_acctbal+10 where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000059	3468.6
 | |
| Customer#000000106	3298.42
 | |
| Customer#000000017	16.34
 | |
| Customer#000000047	284.58
 | |
| Customer#000000092	1192.91
 | |
| Customer#000000101	7480.96
 | |
| Customer#000000022	601.98
 | |
| Customer#000000040	1345.3
 | |
| Customer#000000064	-636.64
 | |
| Customer#000000122	7875.46
 | |
| Customer#000000028	1017.18
 | |
| Customer#000000037	-907.75
 | |
| Customer#000000091	4653.14
 | |
| Customer#000000115	7518.92
 | |
| Customer#000000067	8176.59
 | |
| Customer#000000094	5510.11
 | |
| Customer#000000103	2767.45
 | |
| Customer#000000130	5083.58
 | |
| Customer#000000139	7907.78
 | |
| Customer#000000142	2219.81
 | |
| Customer#000000025	7143.7
 | |
| Customer#000000008	6829.74
 | |
| Customer#000000061	1546.24
 | |
| Customer#000000077	1748.87
 | |
| Customer#000000097	2174.48
 | |
| Customer#000000121	6438.32
 | |
| Customer#000000133	2324.67
 | |
| Customer#000000007	9571.95
 | |
| Customer#000000019	8924.71
 | |
| Customer#000000082	9478.34
 | |
| Customer#000000124	1852.49
 | |
| Customer#000000127	9290.71
 | |
| update customer set c_acctbal = c_acctbal-10 where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000017	6.34
 | |
| Customer#000000047	274.58
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000022	591.98
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000028	1007.18
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000077	1738.87
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000124	1842.49
 | |
| Customer#000000127	9280.71
 | |
| set optimizer_switch='materialization=default';
 | |
| explain
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation where n_name='PERU')
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1993-01-08");
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	customer	ref	PRIMARY,i_c_nationkey	i_c_nationkey	5	dbt3_s001.nation.n_nationkey	6	
 | |
| 1	PRIMARY	orders	ref|filter	i_o_orderdate,i_o_custkey	i_o_custkey|i_o_orderdate	5|4	dbt3_s001.customer.c_custkey	15 (14%)	Using where; FirstMatch(customer); Using rowid filter
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation where n_name='PERU')
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1993-01-08");
 | |
| c_name	c_acctbal
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000035	1228.24
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000133	2314.67
 | |
| explain
 | |
| update customer set c_acctbal = c_acctbal+20 where c_nationkey in (select n_nationkey from nation where n_name='PERU')
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1993-01-08");
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	ref	PRIMARY,i_n_name	i_n_name	26	const	1	Using index condition
 | |
| 1	PRIMARY	customer	ref	PRIMARY,i_c_nationkey	i_c_nationkey	5	dbt3_s001.nation.n_nationkey	6	
 | |
| 1	PRIMARY	orders	ref|filter	i_o_orderdate,i_o_custkey	i_o_custkey|i_o_orderdate	5|4	dbt3_s001.customer.c_custkey	15 (14%)	Using where; FirstMatch(customer); Using rowid filter
 | |
| update customer set c_acctbal = c_acctbal+20 where c_nationkey in (select n_nationkey from nation where n_name='PERU')
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1993-01-08");
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation where n_name='PERU')
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1993-01-08");
 | |
| c_name	c_acctbal
 | |
| Customer#000000008	6839.74
 | |
| Customer#000000035	1248.24
 | |
| Customer#000000061	1556.24
 | |
| Customer#000000097	2184.48
 | |
| Customer#000000121	6448.32
 | |
| Customer#000000133	2334.67
 | |
| update customer set c_acctbal = c_acctbal-20 where c_nationkey in (select n_nationkey from nation where n_name='PERU')
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1993-01-08");
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation where n_name='PERU')
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1993-01-08");
 | |
| c_name	c_acctbal
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000035	1228.24
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000133	2314.67
 | |
| # Materialization
 | |
| # ===============
 | |
| set optimizer_switch='firstmatch=off';
 | |
| explain
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation where
 | |
| n_name in ('JAPAN', 'INDONESIA', 'PERU', 'ARGENTINA'))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1995-01-08");
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	range	PRIMARY,i_n_name	i_n_name	26	NULL	4	Using index condition
 | |
| 1	PRIMARY	customer	ref	PRIMARY,i_c_nationkey	i_c_nationkey	5	dbt3_s001.nation.n_nationkey	6	
 | |
| 1	PRIMARY	<subquery3>	eq_ref	distinct_key	distinct_key	4	func	1	
 | |
| 3	MATERIALIZED	orders	ALL	i_o_orderdate,i_o_custkey	NULL	NULL	NULL	1500	Using where
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation where
 | |
| n_name in ('JAPAN', 'INDONESIA', 'PERU', 'ARGENTINA'))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1995-01-08");
 | |
| c_name	c_acctbal
 | |
| Customer#000000014	5266.3
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000038	6345.11
 | |
| Customer#000000098	-551.37
 | |
| Customer#000000113	2912
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000035	1228.24
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000077	1738.87
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000133	2314.67
 | |
| explain
 | |
| update customer set c_acctbal = c_acctbal+20 where c_nationkey in (select n_nationkey from nation where
 | |
| n_name in ('JAPAN', 'INDONESIA', 'PERU', 'ARGENTINA'))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1995-01-08");
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	nation	range	PRIMARY,i_n_name	i_n_name	26	NULL	4	Using index condition
 | |
| 1	PRIMARY	customer	ref	PRIMARY,i_c_nationkey	i_c_nationkey	5	dbt3_s001.nation.n_nationkey	6	
 | |
| 1	PRIMARY	<subquery3>	eq_ref	distinct_key	distinct_key	4	func	1	
 | |
| 3	MATERIALIZED	orders	ALL	i_o_orderdate,i_o_custkey	NULL	NULL	NULL	1500	Using where
 | |
| update customer set c_acctbal = c_acctbal+20 where c_nationkey in (select n_nationkey from nation where
 | |
| n_name in ('JAPAN', 'INDONESIA', 'PERU', 'ARGENTINA'))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1995-01-08");
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation where
 | |
| n_name in ('JAPAN', 'INDONESIA', 'PERU', 'ARGENTINA'))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1995-01-08");
 | |
| c_name	c_acctbal
 | |
| Customer#000000014	5286.3
 | |
| Customer#000000059	3478.6
 | |
| Customer#000000106	3308.42
 | |
| Customer#000000067	8186.59
 | |
| Customer#000000094	5520.11
 | |
| Customer#000000103	2777.45
 | |
| Customer#000000130	5093.58
 | |
| Customer#000000139	7917.78
 | |
| Customer#000000142	2229.81
 | |
| Customer#000000025	7153.7
 | |
| Customer#000000038	6365.11
 | |
| Customer#000000098	-531.37
 | |
| Customer#000000113	2932
 | |
| Customer#000000008	6839.74
 | |
| Customer#000000035	1248.24
 | |
| Customer#000000061	1556.24
 | |
| Customer#000000077	1758.87
 | |
| Customer#000000097	2184.48
 | |
| Customer#000000121	6448.32
 | |
| Customer#000000133	2334.67
 | |
| update customer set c_acctbal = c_acctbal-20 where c_nationkey in (select n_nationkey from nation where
 | |
| n_name in ('JAPAN', 'INDONESIA', 'PERU', 'ARGENTINA'))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1995-01-08");
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation where
 | |
| n_name in ('JAPAN', 'INDONESIA', 'PERU', 'ARGENTINA'))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between "1992-01-09" and "1995-01-08");
 | |
| c_name	c_acctbal
 | |
| Customer#000000014	5266.3
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000038	6345.11
 | |
| Customer#000000098	-551.37
 | |
| Customer#000000113	2912
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000035	1228.24
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000077	1738.87
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000133	2314.67
 | |
| set optimizer_switch='firstmatch=default';
 | |
| explain
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	customer	ALL	PRIMARY	NULL	NULL	NULL	150	
 | |
| 1	PRIMARY	<subquery2>	eq_ref	distinct_key	distinct_key	4	func	1	
 | |
| 2	MATERIALIZED	orders	ALL	i_o_orderdate,i_o_custkey	NULL	NULL	NULL	1500	Using where
 | |
| explain format=json
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": 0.382051418,
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "customer",
 | |
|           "access_type": "ALL",
 | |
|           "possible_keys": ["PRIMARY"],
 | |
|           "loops": 1,
 | |
|           "rows": 150,
 | |
|           "cost": 0.03493875,
 | |
|           "filtered": 100
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "<subquery2>",
 | |
|           "access_type": "eq_ref",
 | |
|           "possible_keys": ["distinct_key"],
 | |
|           "key": "distinct_key",
 | |
|           "key_length": "4",
 | |
|           "used_key_parts": ["o_custkey"],
 | |
|           "ref": ["func"],
 | |
|           "rows": 1,
 | |
|           "filtered": 100,
 | |
|           "materialized": {
 | |
|             "unique": 1,
 | |
|             "query_block": {
 | |
|               "select_id": 2,
 | |
|               "nested_loop": [
 | |
|                 {
 | |
|                   "table": {
 | |
|                     "table_name": "orders",
 | |
|                     "access_type": "ALL",
 | |
|                     "possible_keys": ["i_o_orderdate", "i_o_custkey"],
 | |
|                     "loops": 1,
 | |
|                     "rows": 1500,
 | |
|                     "cost": 0.2532975,
 | |
|                     "filtered": 16.13333321,
 | |
|                     "attached_condition": "orders.o_orderDATE between '1992-01-09' and '1993-03-08'"
 | |
|                   }
 | |
|                 }
 | |
|               ]
 | |
|             }
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	711.56
 | |
| Customer#000000002	121.65
 | |
| Customer#000000005	794.47
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000010	2753.54
 | |
| Customer#000000011	-272.6
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000014	5266.3
 | |
| Customer#000000016	4681.03
 | |
| Customer#000000017	6.34
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000022	591.98
 | |
| Customer#000000023	3332.02
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000028	1007.18
 | |
| Customer#000000029	7618.27
 | |
| Customer#000000031	5236.89
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000034	8589.7
 | |
| Customer#000000035	1228.24
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000038	6345.11
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000041	270.95
 | |
| Customer#000000043	9904.28
 | |
| Customer#000000044	7315.94
 | |
| Customer#000000046	5744.59
 | |
| Customer#000000047	274.58
 | |
| Customer#000000049	4573.94
 | |
| Customer#000000052	5630.28
 | |
| Customer#000000053	4113.64
 | |
| Customer#000000055	4572.11
 | |
| Customer#000000056	6530.86
 | |
| Customer#000000058	6478.46
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000062	595.61
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000065	8795.16
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000070	4867.52
 | |
| Customer#000000071	-611.19
 | |
| Customer#000000073	4288.5
 | |
| Customer#000000074	2764.43
 | |
| Customer#000000076	5745.33
 | |
| Customer#000000079	5121.28
 | |
| Customer#000000080	7383.53
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000083	6463.51
 | |
| Customer#000000085	3386.64
 | |
| Customer#000000086	3306.32
 | |
| Customer#000000088	8031.44
 | |
| Customer#000000089	1530.76
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000095	5327.38
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000098	-551.37
 | |
| Customer#000000100	9889.89
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000104	-588.38
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000107	2514.15
 | |
| Customer#000000109	-716.1
 | |
| Customer#000000110	7462.99
 | |
| Customer#000000112	2953.35
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000116	8403.99
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000127	9280.71
 | |
| Customer#000000128	-986.96
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000131	8595.53
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000134	4608.9
 | |
| Customer#000000136	-842.39
 | |
| Customer#000000137	7838.3
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000140	9963.15
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000143	2186.5
 | |
| Customer#000000145	9748.93
 | |
| Customer#000000148	2135.6
 | |
| Customer#000000149	8959.65
 | |
| explain
 | |
| update customer set c_acctbal = c_acctbal+5 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	customer	ALL	PRIMARY	NULL	NULL	NULL	150	
 | |
| 1	PRIMARY	<subquery2>	eq_ref	distinct_key	distinct_key	4	func	1	
 | |
| 2	MATERIALIZED	orders	ALL	i_o_orderdate,i_o_custkey	NULL	NULL	NULL	1500	Using where
 | |
| explain format=json
 | |
| update customer set c_acctbal = c_acctbal+5 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": "COST_REPLACED",
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "customer",
 | |
|           "access_type": "ALL",
 | |
|           "possible_keys": ["PRIMARY"],
 | |
|           "loops": 1,
 | |
|           "rows": 150,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 100
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "<subquery2>",
 | |
|           "access_type": "eq_ref",
 | |
|           "possible_keys": ["distinct_key"],
 | |
|           "key": "distinct_key",
 | |
|           "key_length": "4",
 | |
|           "used_key_parts": ["o_custkey"],
 | |
|           "ref": ["func"],
 | |
|           "rows": 1,
 | |
|           "filtered": 100,
 | |
|           "materialized": {
 | |
|             "unique": 1,
 | |
|             "query_block": {
 | |
|               "select_id": 2,
 | |
|               "nested_loop": [
 | |
|                 {
 | |
|                   "table": {
 | |
|                     "table_name": "orders",
 | |
|                     "access_type": "ALL",
 | |
|                     "possible_keys": ["i_o_orderdate", "i_o_custkey"],
 | |
|                     "loops": 1,
 | |
|                     "rows": 1500,
 | |
|                     "cost": "COST_REPLACED",
 | |
|                     "filtered": 16.13333321,
 | |
|                     "attached_condition": "orders.o_orderDATE between '1992-01-09' and '1993-03-08'"
 | |
|                   }
 | |
|                 }
 | |
|               ]
 | |
|             }
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| update customer set c_acctbal = c_acctbal+5 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	716.56
 | |
| Customer#000000002	126.65
 | |
| Customer#000000005	799.47
 | |
| Customer#000000007	9566.95
 | |
| Customer#000000008	6824.74
 | |
| Customer#000000010	2758.54
 | |
| Customer#000000011	-267.6
 | |
| Customer#000000013	3862.34
 | |
| Customer#000000014	5271.3
 | |
| Customer#000000016	4686.03
 | |
| Customer#000000017	11.34
 | |
| Customer#000000019	8919.71
 | |
| Customer#000000022	596.98
 | |
| Customer#000000023	3337.02
 | |
| Customer#000000025	7138.7
 | |
| Customer#000000028	1012.18
 | |
| Customer#000000029	7623.27
 | |
| Customer#000000031	5241.89
 | |
| Customer#000000032	3476.53
 | |
| Customer#000000034	8594.7
 | |
| Customer#000000035	1233.24
 | |
| Customer#000000037	-912.75
 | |
| Customer#000000038	6350.11
 | |
| Customer#000000040	1340.3
 | |
| Customer#000000041	275.95
 | |
| Customer#000000043	9909.28
 | |
| Customer#000000044	7320.94
 | |
| Customer#000000046	5749.59
 | |
| Customer#000000047	279.58
 | |
| Customer#000000049	4578.94
 | |
| Customer#000000052	5635.28
 | |
| Customer#000000053	4118.64
 | |
| Customer#000000055	4577.11
 | |
| Customer#000000056	6535.86
 | |
| Customer#000000058	6483.46
 | |
| Customer#000000059	3463.6
 | |
| Customer#000000061	1541.24
 | |
| Customer#000000062	600.61
 | |
| Customer#000000064	-641.64
 | |
| Customer#000000065	8800.16
 | |
| Customer#000000067	8171.59
 | |
| Customer#000000070	4872.52
 | |
| Customer#000000071	-606.19
 | |
| Customer#000000073	4293.5
 | |
| Customer#000000074	2769.43
 | |
| Customer#000000076	5750.33
 | |
| Customer#000000079	5126.28
 | |
| Customer#000000080	7388.53
 | |
| Customer#000000082	9473.34
 | |
| Customer#000000083	6468.51
 | |
| Customer#000000085	3391.64
 | |
| Customer#000000086	3311.32
 | |
| Customer#000000088	8036.44
 | |
| Customer#000000089	1535.76
 | |
| Customer#000000091	4648.14
 | |
| Customer#000000092	1187.91
 | |
| Customer#000000094	5505.11
 | |
| Customer#000000095	5332.38
 | |
| Customer#000000097	2169.48
 | |
| Customer#000000098	-546.37
 | |
| Customer#000000100	9894.89
 | |
| Customer#000000101	7475.96
 | |
| Customer#000000103	2762.45
 | |
| Customer#000000104	-583.38
 | |
| Customer#000000106	3293.42
 | |
| Customer#000000107	2519.15
 | |
| Customer#000000109	-711.1
 | |
| Customer#000000110	7467.99
 | |
| Customer#000000112	2958.35
 | |
| Customer#000000115	7513.92
 | |
| Customer#000000116	8408.99
 | |
| Customer#000000118	3587.37
 | |
| Customer#000000121	6433.32
 | |
| Customer#000000122	7870.46
 | |
| Customer#000000127	9285.71
 | |
| Customer#000000128	-981.96
 | |
| Customer#000000130	5078.58
 | |
| Customer#000000131	8600.53
 | |
| Customer#000000133	2319.67
 | |
| Customer#000000134	4613.9
 | |
| Customer#000000136	-837.39
 | |
| Customer#000000137	7843.3
 | |
| Customer#000000139	7902.78
 | |
| Customer#000000140	9968.15
 | |
| Customer#000000142	2214.81
 | |
| Customer#000000143	2191.5
 | |
| Customer#000000145	9753.93
 | |
| Customer#000000148	2140.6
 | |
| Customer#000000149	8964.65
 | |
| update customer set c_acctbal = c_acctbal-5 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	711.56
 | |
| Customer#000000002	121.65
 | |
| Customer#000000005	794.47
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000010	2753.54
 | |
| Customer#000000011	-272.6
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000014	5266.3
 | |
| Customer#000000016	4681.03
 | |
| Customer#000000017	6.34
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000022	591.98
 | |
| Customer#000000023	3332.02
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000028	1007.18
 | |
| Customer#000000029	7618.27
 | |
| Customer#000000031	5236.89
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000034	8589.7
 | |
| Customer#000000035	1228.24
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000038	6345.11
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000041	270.95
 | |
| Customer#000000043	9904.28
 | |
| Customer#000000044	7315.94
 | |
| Customer#000000046	5744.59
 | |
| Customer#000000047	274.58
 | |
| Customer#000000049	4573.94
 | |
| Customer#000000052	5630.28
 | |
| Customer#000000053	4113.64
 | |
| Customer#000000055	4572.11
 | |
| Customer#000000056	6530.86
 | |
| Customer#000000058	6478.46
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000062	595.61
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000065	8795.16
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000070	4867.52
 | |
| Customer#000000071	-611.19
 | |
| Customer#000000073	4288.5
 | |
| Customer#000000074	2764.43
 | |
| Customer#000000076	5745.33
 | |
| Customer#000000079	5121.28
 | |
| Customer#000000080	7383.53
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000083	6463.51
 | |
| Customer#000000085	3386.64
 | |
| Customer#000000086	3306.32
 | |
| Customer#000000088	8031.44
 | |
| Customer#000000089	1530.76
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000095	5327.38
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000098	-551.37
 | |
| Customer#000000100	9889.89
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000104	-588.38
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000107	2514.15
 | |
| Customer#000000109	-716.1
 | |
| Customer#000000110	7462.99
 | |
| Customer#000000112	2953.35
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000116	8403.99
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000127	9280.71
 | |
| Customer#000000128	-986.96
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000131	8595.53
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000134	4608.9
 | |
| Customer#000000136	-842.39
 | |
| Customer#000000137	7838.3
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000140	9963.15
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000143	2186.5
 | |
| Customer#000000145	9748.93
 | |
| Customer#000000148	2135.6
 | |
| Customer#000000149	8959.65
 | |
| explain
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-06-09' and '1993-01-08');
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	customer	ALL	PRIMARY	NULL	NULL	NULL	150	
 | |
| 1	PRIMARY	<subquery2>	eq_ref	distinct_key	distinct_key	4	func	1	
 | |
| 2	MATERIALIZED	orders	range	i_o_orderdate,i_o_custkey	i_o_orderdate	4	NULL	114	Using index condition; Using where
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-06-09' and '1993-01-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	711.56
 | |
| Customer#000000002	121.65
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000010	2753.54
 | |
| Customer#000000011	-272.6
 | |
| Customer#000000016	4681.03
 | |
| Customer#000000017	6.34
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000022	591.98
 | |
| Customer#000000023	3332.02
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000028	1007.18
 | |
| Customer#000000029	7618.27
 | |
| Customer#000000031	5236.89
 | |
| Customer#000000034	8589.7
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000043	9904.28
 | |
| Customer#000000044	7315.94
 | |
| Customer#000000046	5744.59
 | |
| Customer#000000047	274.58
 | |
| Customer#000000049	4573.94
 | |
| Customer#000000053	4113.64
 | |
| Customer#000000055	4572.11
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000070	4867.52
 | |
| Customer#000000071	-611.19
 | |
| Customer#000000073	4288.5
 | |
| Customer#000000074	2764.43
 | |
| Customer#000000076	5745.33
 | |
| Customer#000000079	5121.28
 | |
| Customer#000000080	7383.53
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000083	6463.51
 | |
| Customer#000000085	3386.64
 | |
| Customer#000000086	3306.32
 | |
| Customer#000000088	8031.44
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000095	5327.38
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000100	9889.89
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000104	-588.38
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000109	-716.1
 | |
| Customer#000000110	7462.99
 | |
| Customer#000000112	2953.35
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000127	9280.71
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000131	8595.53
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000134	4608.9
 | |
| Customer#000000136	-842.39
 | |
| Customer#000000137	7838.3
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000143	2186.5
 | |
| Customer#000000148	2135.6
 | |
| Customer#000000149	8959.65
 | |
| explain
 | |
| update customer set c_acctbal = c_acctbal+1 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-06-09' and '1993-01-08');
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	customer	ALL	PRIMARY	NULL	NULL	NULL	150	
 | |
| 1	PRIMARY	<subquery2>	eq_ref	distinct_key	distinct_key	4	func	1	
 | |
| 2	MATERIALIZED	orders	range	i_o_orderdate,i_o_custkey	i_o_orderdate	4	NULL	114	Using index condition; Using where
 | |
| update customer set c_acctbal = c_acctbal+1 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-06-09' and '1993-01-08');
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-06-09' and '1993-01-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	712.56
 | |
| Customer#000000002	122.65
 | |
| Customer#000000007	9562.95
 | |
| Customer#000000008	6820.74
 | |
| Customer#000000010	2754.54
 | |
| Customer#000000011	-271.6
 | |
| Customer#000000016	4682.03
 | |
| Customer#000000017	7.34
 | |
| Customer#000000019	8915.71
 | |
| Customer#000000022	592.98
 | |
| Customer#000000023	3333.02
 | |
| Customer#000000025	7134.7
 | |
| Customer#000000028	1008.18
 | |
| Customer#000000029	7619.27
 | |
| Customer#000000031	5237.89
 | |
| Customer#000000034	8590.7
 | |
| Customer#000000037	-916.75
 | |
| Customer#000000040	1336.3
 | |
| Customer#000000043	9905.28
 | |
| Customer#000000044	7316.94
 | |
| Customer#000000046	5745.59
 | |
| Customer#000000047	275.58
 | |
| Customer#000000049	4574.94
 | |
| Customer#000000053	4114.64
 | |
| Customer#000000055	4573.11
 | |
| Customer#000000061	1537.24
 | |
| Customer#000000064	-645.64
 | |
| Customer#000000067	8167.59
 | |
| Customer#000000070	4868.52
 | |
| Customer#000000071	-610.19
 | |
| Customer#000000073	4289.5
 | |
| Customer#000000074	2765.43
 | |
| Customer#000000076	5746.33
 | |
| Customer#000000079	5122.28
 | |
| Customer#000000080	7384.53
 | |
| Customer#000000082	9469.34
 | |
| Customer#000000083	6464.51
 | |
| Customer#000000085	3387.64
 | |
| Customer#000000086	3307.32
 | |
| Customer#000000088	8032.44
 | |
| Customer#000000091	4644.14
 | |
| Customer#000000092	1183.91
 | |
| Customer#000000095	5328.38
 | |
| Customer#000000097	2165.48
 | |
| Customer#000000100	9890.89
 | |
| Customer#000000101	7471.96
 | |
| Customer#000000103	2758.45
 | |
| Customer#000000104	-587.38
 | |
| Customer#000000106	3289.42
 | |
| Customer#000000109	-715.1
 | |
| Customer#000000110	7463.99
 | |
| Customer#000000112	2954.35
 | |
| Customer#000000118	3583.37
 | |
| Customer#000000121	6429.32
 | |
| Customer#000000122	7866.46
 | |
| Customer#000000127	9281.71
 | |
| Customer#000000130	5074.58
 | |
| Customer#000000131	8596.53
 | |
| Customer#000000133	2315.67
 | |
| Customer#000000134	4609.9
 | |
| Customer#000000136	-841.39
 | |
| Customer#000000137	7839.3
 | |
| Customer#000000139	7898.78
 | |
| Customer#000000142	2210.81
 | |
| Customer#000000143	2187.5
 | |
| Customer#000000148	2136.6
 | |
| Customer#000000149	8960.65
 | |
| update customer set c_acctbal = c_acctbal-1 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-06-09' and '1993-01-08');
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-06-09' and '1993-01-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	711.56
 | |
| Customer#000000002	121.65
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000010	2753.54
 | |
| Customer#000000011	-272.6
 | |
| Customer#000000016	4681.03
 | |
| Customer#000000017	6.34
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000022	591.98
 | |
| Customer#000000023	3332.02
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000028	1007.18
 | |
| Customer#000000029	7618.27
 | |
| Customer#000000031	5236.89
 | |
| Customer#000000034	8589.7
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000043	9904.28
 | |
| Customer#000000044	7315.94
 | |
| Customer#000000046	5744.59
 | |
| Customer#000000047	274.58
 | |
| Customer#000000049	4573.94
 | |
| Customer#000000053	4113.64
 | |
| Customer#000000055	4572.11
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000070	4867.52
 | |
| Customer#000000071	-611.19
 | |
| Customer#000000073	4288.5
 | |
| Customer#000000074	2764.43
 | |
| Customer#000000076	5745.33
 | |
| Customer#000000079	5121.28
 | |
| Customer#000000080	7383.53
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000083	6463.51
 | |
| Customer#000000085	3386.64
 | |
| Customer#000000086	3306.32
 | |
| Customer#000000088	8031.44
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000095	5327.38
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000100	9889.89
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000104	-588.38
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000109	-716.1
 | |
| Customer#000000110	7462.99
 | |
| Customer#000000112	2953.35
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000127	9280.71
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000131	8595.53
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000134	4608.9
 | |
| Customer#000000136	-842.39
 | |
| Customer#000000137	7838.3
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000143	2186.5
 | |
| Customer#000000148	2135.6
 | |
| Customer#000000149	8959.65
 | |
| # Materialization SJM
 | |
| # ===================
 | |
| explain
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	<subquery2>	ALL	distinct_key	NULL	NULL	NULL	28	
 | |
| 1	PRIMARY	customer	eq_ref	PRIMARY	PRIMARY	4	<subquery2>.o_custkey	1	
 | |
| 2	MATERIALIZED	orders	range	i_o_orderdate	i_o_orderdate	4	NULL	28	Using index condition; Using temporary
 | |
| explain format=json
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": "COST_REPLACED",
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "<subquery2>",
 | |
|           "access_type": "ALL",
 | |
|           "possible_keys": ["distinct_key"],
 | |
|           "loops": 1,
 | |
|           "rows": 28,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 100,
 | |
|           "materialized": {
 | |
|             "unique": 1,
 | |
|             "materialization": {
 | |
|               "query_block": {
 | |
|                 "select_id": 2,
 | |
|                 "cost": "COST_REPLACED",
 | |
|                 "having_condition": "count(orders.o_custkey) > 1",
 | |
|                 "temporary_table": {
 | |
|                   "nested_loop": [
 | |
|                     {
 | |
|                       "table": {
 | |
|                         "table_name": "orders",
 | |
|                         "access_type": "range",
 | |
|                         "possible_keys": ["i_o_orderdate"],
 | |
|                         "key": "i_o_orderdate",
 | |
|                         "key_length": "4",
 | |
|                         "used_key_parts": ["o_orderDATE"],
 | |
|                         "loops": 1,
 | |
|                         "rows": 28,
 | |
|                         "cost": "COST_REPLACED",
 | |
|                         "filtered": 100,
 | |
|                         "index_condition": "orders.o_orderDATE between '1992-01-09' and '1992-03-08'"
 | |
|                       }
 | |
|                     }
 | |
|                   ]
 | |
|                 }
 | |
|               }
 | |
|             }
 | |
|           }
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "customer",
 | |
|           "access_type": "eq_ref",
 | |
|           "possible_keys": ["PRIMARY"],
 | |
|           "key": "PRIMARY",
 | |
|           "key_length": "4",
 | |
|           "used_key_parts": ["c_custkey"],
 | |
|           "ref": ["<subquery2>.o_custkey"],
 | |
|           "loops": 28,
 | |
|           "rows": 1,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 100
 | |
|         }
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| c_name	c_acctbal
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000056	6530.86
 | |
| explain
 | |
| update customer set c_acctbal = c_acctbal-5 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	<subquery2>	ALL	distinct_key	NULL	NULL	NULL	28	
 | |
| 1	PRIMARY	customer	eq_ref	PRIMARY	PRIMARY	4	<subquery2>.o_custkey	1	
 | |
| 2	MATERIALIZED	orders	range	i_o_orderdate	i_o_orderdate	4	NULL	28	Using index condition; Using temporary
 | |
| explain format=json
 | |
| update customer set c_acctbal = c_acctbal-5 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": "COST_REPLACED",
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "<subquery2>",
 | |
|           "access_type": "ALL",
 | |
|           "possible_keys": ["distinct_key"],
 | |
|           "loops": 1,
 | |
|           "rows": 28,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 100,
 | |
|           "materialized": {
 | |
|             "unique": 1,
 | |
|             "materialization": {
 | |
|               "query_block": {
 | |
|                 "select_id": 2,
 | |
|                 "cost": "COST_REPLACED",
 | |
|                 "having_condition": "count(orders.o_custkey) > 1",
 | |
|                 "temporary_table": {
 | |
|                   "nested_loop": [
 | |
|                     {
 | |
|                       "table": {
 | |
|                         "table_name": "orders",
 | |
|                         "access_type": "range",
 | |
|                         "possible_keys": ["i_o_orderdate"],
 | |
|                         "key": "i_o_orderdate",
 | |
|                         "key_length": "4",
 | |
|                         "used_key_parts": ["o_orderDATE"],
 | |
|                         "loops": 1,
 | |
|                         "rows": 28,
 | |
|                         "cost": "COST_REPLACED",
 | |
|                         "filtered": 100,
 | |
|                         "index_condition": "orders.o_orderDATE between '1992-01-09' and '1992-03-08'"
 | |
|                       }
 | |
|                     }
 | |
|                   ]
 | |
|                 }
 | |
|               }
 | |
|             }
 | |
|           }
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "customer",
 | |
|           "access_type": "eq_ref",
 | |
|           "possible_keys": ["PRIMARY"],
 | |
|           "key": "PRIMARY",
 | |
|           "key_length": "4",
 | |
|           "used_key_parts": ["c_custkey"],
 | |
|           "ref": ["<subquery2>.o_custkey"],
 | |
|           "loops": 28,
 | |
|           "rows": 1,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 100
 | |
|         }
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| update customer set c_acctbal = c_acctbal-5 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| c_name	c_acctbal
 | |
| Customer#000000013	3852.34
 | |
| Customer#000000032	3466.53
 | |
| Customer#000000037	-922.75
 | |
| Customer#000000118	3577.37
 | |
| Customer#000000056	6525.86
 | |
| update customer set c_acctbal = c_acctbal+5 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| c_name	c_acctbal
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000056	6530.86
 | |
| explain
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 5);
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	customer	ALL	PRIMARY	NULL	NULL	NULL	150	
 | |
| 1	PRIMARY	<subquery2>	eq_ref	distinct_key	distinct_key	4	dbt3_s001.customer.c_custkey	1	
 | |
| 2	MATERIALIZED	orders	ALL	i_o_orderdate	NULL	NULL	NULL	1500	Using where; Using temporary
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 5);
 | |
| c_name	c_acctbal
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000016	4681.03
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000046	5744.59
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000134	4608.9
 | |
| explain
 | |
| update customer set c_acctbal = c_acctbal-1 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 5);
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	customer	ALL	PRIMARY	NULL	NULL	NULL	150	
 | |
| 1	PRIMARY	<subquery2>	eq_ref	distinct_key	distinct_key	4	dbt3_s001.customer.c_custkey	1	
 | |
| 2	MATERIALIZED	orders	ALL	i_o_orderdate	NULL	NULL	NULL	1500	Using where; Using temporary
 | |
| update customer set c_acctbal = c_acctbal-1 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 5);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 5);
 | |
| c_name	c_acctbal
 | |
| Customer#000000007	9560.95
 | |
| Customer#000000016	4680.03
 | |
| Customer#000000037	-918.75
 | |
| Customer#000000046	5743.59
 | |
| Customer#000000091	4642.14
 | |
| Customer#000000103	2756.45
 | |
| Customer#000000118	3581.37
 | |
| Customer#000000133	2313.67
 | |
| Customer#000000134	4607.9
 | |
| update customer set c_acctbal = c_acctbal+1 where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 5);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 5);
 | |
| c_name	c_acctbal
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000016	4681.03
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000046	5744.59
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000134	4608.9
 | |
| # Pullout PS
 | |
| # ==========
 | |
| prepare stmt from "
 | |
| update orders set o_totalprice = o_totalprice+? where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| ";
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| o_orderkey	o_totalprice
 | |
| 644	201268.06
 | |
| 2880	145761.99
 | |
| 3142	16030.15
 | |
| 5382	138423.03
 | |
| 5095	184583.99
 | |
| 737	12984.85
 | |
| 1729	12137.76
 | |
| 5121	150334.57
 | |
| set @a1=-20;
 | |
| execute stmt using @a1;
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| o_orderkey	o_totalprice
 | |
| 644	201248.06
 | |
| 2880	145741.99
 | |
| 3142	16010.15
 | |
| 5382	138403.03
 | |
| 5095	184563.99
 | |
| 737	12964.85
 | |
| 1729	12117.76
 | |
| 5121	150314.57
 | |
| set @a2=-10;
 | |
| execute stmt using @a2;
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| o_orderkey	o_totalprice
 | |
| 644	201238.06
 | |
| 2880	145731.99
 | |
| 3142	16000.15
 | |
| 5382	138393.03
 | |
| 5095	184553.99
 | |
| 737	12954.85
 | |
| 1729	12107.76
 | |
| 5121	150304.57
 | |
| execute stmt using -(@a1+@a2);
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| o_orderkey	o_totalprice
 | |
| 644	201268.06
 | |
| 2880	145761.99
 | |
| 3142	16030.15
 | |
| 5382	138423.03
 | |
| 5095	184583.99
 | |
| 737	12984.85
 | |
| 1729	12137.76
 | |
| 5121	150334.57
 | |
| deallocate prepare stmt;
 | |
| # FirstMatch PS
 | |
| # =============
 | |
| set optimizer_switch='materialization=off';
 | |
| prepare stmt from "
 | |
| update customer set c_acctbal = c_acctbal+? where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| ";
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000017	6.34
 | |
| Customer#000000047	274.58
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000022	591.98
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000028	1007.18
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000077	1738.87
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000124	1842.49
 | |
| Customer#000000127	9280.71
 | |
| set @a1=15;
 | |
| execute stmt using @a1;
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000059	3473.6
 | |
| Customer#000000106	3303.42
 | |
| Customer#000000017	21.34
 | |
| Customer#000000047	289.58
 | |
| Customer#000000092	1197.91
 | |
| Customer#000000101	7485.96
 | |
| Customer#000000022	606.98
 | |
| Customer#000000040	1350.3
 | |
| Customer#000000064	-631.64
 | |
| Customer#000000122	7880.46
 | |
| Customer#000000028	1022.18
 | |
| Customer#000000037	-902.75
 | |
| Customer#000000091	4658.14
 | |
| Customer#000000115	7523.92
 | |
| Customer#000000067	8181.59
 | |
| Customer#000000094	5515.11
 | |
| Customer#000000103	2772.45
 | |
| Customer#000000130	5088.58
 | |
| Customer#000000139	7912.78
 | |
| Customer#000000142	2224.81
 | |
| Customer#000000025	7148.7
 | |
| Customer#000000008	6834.74
 | |
| Customer#000000061	1551.24
 | |
| Customer#000000077	1753.87
 | |
| Customer#000000097	2179.48
 | |
| Customer#000000121	6443.32
 | |
| Customer#000000133	2329.67
 | |
| Customer#000000007	9576.95
 | |
| Customer#000000019	8929.71
 | |
| Customer#000000082	9483.34
 | |
| Customer#000000124	1857.49
 | |
| Customer#000000127	9295.71
 | |
| set @a2=5;
 | |
| execute stmt using @a2;
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000059	3478.6
 | |
| Customer#000000106	3308.42
 | |
| Customer#000000017	26.34
 | |
| Customer#000000047	294.58
 | |
| Customer#000000092	1202.91
 | |
| Customer#000000101	7490.96
 | |
| Customer#000000022	611.98
 | |
| Customer#000000040	1355.3
 | |
| Customer#000000064	-626.64
 | |
| Customer#000000122	7885.46
 | |
| Customer#000000028	1027.1799999999998
 | |
| Customer#000000037	-897.75
 | |
| Customer#000000091	4663.14
 | |
| Customer#000000115	7528.92
 | |
| Customer#000000067	8186.59
 | |
| Customer#000000094	5520.11
 | |
| Customer#000000103	2777.45
 | |
| Customer#000000130	5093.58
 | |
| Customer#000000139	7917.78
 | |
| Customer#000000142	2229.81
 | |
| Customer#000000025	7153.7
 | |
| Customer#000000008	6839.74
 | |
| Customer#000000061	1556.24
 | |
| Customer#000000077	1758.87
 | |
| Customer#000000097	2184.48
 | |
| Customer#000000121	6448.32
 | |
| Customer#000000133	2334.67
 | |
| Customer#000000007	9581.95
 | |
| Customer#000000019	8934.71
 | |
| Customer#000000082	9488.34
 | |
| Customer#000000124	1862.49
 | |
| Customer#000000127	9300.71
 | |
| execute stmt using -(@a1+@a2);
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000017	6.34
 | |
| Customer#000000047	274.58
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000022	591.98
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000028	1007.1799999999998
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000077	1738.87
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000124	1842.49
 | |
| Customer#000000127	9280.71
 | |
| deallocate prepare stmt;
 | |
| set optimizer_switch='materialization=default';
 | |
| # Materialization PS
 | |
| # ==================
 | |
| prepare stmt from "
 | |
| update customer set c_acctbal = c_acctbal+? where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| ";
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	711.56
 | |
| Customer#000000002	121.65
 | |
| Customer#000000005	794.47
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000010	2753.54
 | |
| Customer#000000011	-272.6
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000014	5266.3
 | |
| Customer#000000016	4681.03
 | |
| Customer#000000017	6.34
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000022	591.98
 | |
| Customer#000000023	3332.02
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000028	1007.1799999999998
 | |
| Customer#000000029	7618.27
 | |
| Customer#000000031	5236.89
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000034	8589.7
 | |
| Customer#000000035	1228.24
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000038	6345.11
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000041	270.95
 | |
| Customer#000000043	9904.28
 | |
| Customer#000000044	7315.94
 | |
| Customer#000000046	5744.59
 | |
| Customer#000000047	274.58
 | |
| Customer#000000049	4573.94
 | |
| Customer#000000052	5630.28
 | |
| Customer#000000053	4113.64
 | |
| Customer#000000055	4572.11
 | |
| Customer#000000056	6530.86
 | |
| Customer#000000058	6478.46
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000062	595.61
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000065	8795.16
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000070	4867.52
 | |
| Customer#000000071	-611.19
 | |
| Customer#000000073	4288.5
 | |
| Customer#000000074	2764.43
 | |
| Customer#000000076	5745.33
 | |
| Customer#000000079	5121.28
 | |
| Customer#000000080	7383.53
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000083	6463.51
 | |
| Customer#000000085	3386.64
 | |
| Customer#000000086	3306.32
 | |
| Customer#000000088	8031.44
 | |
| Customer#000000089	1530.76
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000095	5327.38
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000098	-551.37
 | |
| Customer#000000100	9889.89
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000104	-588.38
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000107	2514.15
 | |
| Customer#000000109	-716.1
 | |
| Customer#000000110	7462.99
 | |
| Customer#000000112	2953.35
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000116	8403.99
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000127	9280.71
 | |
| Customer#000000128	-986.96
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000131	8595.53
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000134	4608.9
 | |
| Customer#000000136	-842.39
 | |
| Customer#000000137	7838.3
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000140	9963.15
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000143	2186.5
 | |
| Customer#000000145	9748.93
 | |
| Customer#000000148	2135.6
 | |
| Customer#000000149	8959.65
 | |
| set @a1=7;
 | |
| execute stmt using @a1;
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	718.56
 | |
| Customer#000000002	128.65
 | |
| Customer#000000005	801.47
 | |
| Customer#000000007	9568.95
 | |
| Customer#000000008	6826.74
 | |
| Customer#000000010	2760.54
 | |
| Customer#000000011	-265.6
 | |
| Customer#000000013	3864.34
 | |
| Customer#000000014	5273.3
 | |
| Customer#000000016	4688.03
 | |
| Customer#000000017	13.34
 | |
| Customer#000000019	8921.71
 | |
| Customer#000000022	598.98
 | |
| Customer#000000023	3339.02
 | |
| Customer#000000025	7140.7
 | |
| Customer#000000028	1014.1799999999998
 | |
| Customer#000000029	7625.27
 | |
| Customer#000000031	5243.89
 | |
| Customer#000000032	3478.53
 | |
| Customer#000000034	8596.7
 | |
| Customer#000000035	1235.24
 | |
| Customer#000000037	-910.75
 | |
| Customer#000000038	6352.11
 | |
| Customer#000000040	1342.3
 | |
| Customer#000000041	277.95
 | |
| Customer#000000043	9911.28
 | |
| Customer#000000044	7322.94
 | |
| Customer#000000046	5751.59
 | |
| Customer#000000047	281.58
 | |
| Customer#000000049	4580.94
 | |
| Customer#000000052	5637.28
 | |
| Customer#000000053	4120.64
 | |
| Customer#000000055	4579.11
 | |
| Customer#000000056	6537.86
 | |
| Customer#000000058	6485.46
 | |
| Customer#000000059	3465.6
 | |
| Customer#000000061	1543.24
 | |
| Customer#000000062	602.61
 | |
| Customer#000000064	-639.64
 | |
| Customer#000000065	8802.16
 | |
| Customer#000000067	8173.59
 | |
| Customer#000000070	4874.52
 | |
| Customer#000000071	-604.19
 | |
| Customer#000000073	4295.5
 | |
| Customer#000000074	2771.43
 | |
| Customer#000000076	5752.33
 | |
| Customer#000000079	5128.28
 | |
| Customer#000000080	7390.53
 | |
| Customer#000000082	9475.34
 | |
| Customer#000000083	6470.51
 | |
| Customer#000000085	3393.64
 | |
| Customer#000000086	3313.32
 | |
| Customer#000000088	8038.44
 | |
| Customer#000000089	1537.76
 | |
| Customer#000000091	4650.14
 | |
| Customer#000000092	1189.91
 | |
| Customer#000000094	5507.11
 | |
| Customer#000000095	5334.38
 | |
| Customer#000000097	2171.48
 | |
| Customer#000000098	-544.37
 | |
| Customer#000000100	9896.89
 | |
| Customer#000000101	7477.96
 | |
| Customer#000000103	2764.45
 | |
| Customer#000000104	-581.38
 | |
| Customer#000000106	3295.42
 | |
| Customer#000000107	2521.15
 | |
| Customer#000000109	-709.1
 | |
| Customer#000000110	7469.99
 | |
| Customer#000000112	2960.35
 | |
| Customer#000000115	7515.92
 | |
| Customer#000000116	8410.99
 | |
| Customer#000000118	3589.37
 | |
| Customer#000000121	6435.32
 | |
| Customer#000000122	7872.46
 | |
| Customer#000000127	9287.71
 | |
| Customer#000000128	-979.96
 | |
| Customer#000000130	5080.58
 | |
| Customer#000000131	8602.53
 | |
| Customer#000000133	2321.67
 | |
| Customer#000000134	4615.9
 | |
| Customer#000000136	-835.39
 | |
| Customer#000000137	7845.3
 | |
| Customer#000000139	7904.78
 | |
| Customer#000000140	9970.15
 | |
| Customer#000000142	2216.81
 | |
| Customer#000000143	2193.5
 | |
| Customer#000000145	9755.93
 | |
| Customer#000000148	2142.6
 | |
| Customer#000000149	8966.65
 | |
| set @a2=3;
 | |
| execute stmt using @a2;
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	721.56
 | |
| Customer#000000002	131.65
 | |
| Customer#000000005	804.47
 | |
| Customer#000000007	9571.95
 | |
| Customer#000000008	6829.74
 | |
| Customer#000000010	2763.54
 | |
| Customer#000000011	-262.6
 | |
| Customer#000000013	3867.34
 | |
| Customer#000000014	5276.3
 | |
| Customer#000000016	4691.03
 | |
| Customer#000000017	16.34
 | |
| Customer#000000019	8924.71
 | |
| Customer#000000022	601.98
 | |
| Customer#000000023	3342.02
 | |
| Customer#000000025	7143.7
 | |
| Customer#000000028	1017.1799999999998
 | |
| Customer#000000029	7628.27
 | |
| Customer#000000031	5246.89
 | |
| Customer#000000032	3481.53
 | |
| Customer#000000034	8599.7
 | |
| Customer#000000035	1238.24
 | |
| Customer#000000037	-907.75
 | |
| Customer#000000038	6355.11
 | |
| Customer#000000040	1345.3
 | |
| Customer#000000041	280.95
 | |
| Customer#000000043	9914.28
 | |
| Customer#000000044	7325.94
 | |
| Customer#000000046	5754.59
 | |
| Customer#000000047	284.58
 | |
| Customer#000000049	4583.94
 | |
| Customer#000000052	5640.28
 | |
| Customer#000000053	4123.64
 | |
| Customer#000000055	4582.11
 | |
| Customer#000000056	6540.86
 | |
| Customer#000000058	6488.46
 | |
| Customer#000000059	3468.6
 | |
| Customer#000000061	1546.24
 | |
| Customer#000000062	605.61
 | |
| Customer#000000064	-636.64
 | |
| Customer#000000065	8805.16
 | |
| Customer#000000067	8176.59
 | |
| Customer#000000070	4877.52
 | |
| Customer#000000071	-601.19
 | |
| Customer#000000073	4298.5
 | |
| Customer#000000074	2774.43
 | |
| Customer#000000076	5755.33
 | |
| Customer#000000079	5131.28
 | |
| Customer#000000080	7393.53
 | |
| Customer#000000082	9478.34
 | |
| Customer#000000083	6473.51
 | |
| Customer#000000085	3396.64
 | |
| Customer#000000086	3316.32
 | |
| Customer#000000088	8041.44
 | |
| Customer#000000089	1540.76
 | |
| Customer#000000091	4653.14
 | |
| Customer#000000092	1192.91
 | |
| Customer#000000094	5510.11
 | |
| Customer#000000095	5337.38
 | |
| Customer#000000097	2174.48
 | |
| Customer#000000098	-541.37
 | |
| Customer#000000100	9899.89
 | |
| Customer#000000101	7480.96
 | |
| Customer#000000103	2767.45
 | |
| Customer#000000104	-578.38
 | |
| Customer#000000106	3298.42
 | |
| Customer#000000107	2524.15
 | |
| Customer#000000109	-706.1
 | |
| Customer#000000110	7472.99
 | |
| Customer#000000112	2963.35
 | |
| Customer#000000115	7518.92
 | |
| Customer#000000116	8413.99
 | |
| Customer#000000118	3592.37
 | |
| Customer#000000121	6438.32
 | |
| Customer#000000122	7875.46
 | |
| Customer#000000127	9290.71
 | |
| Customer#000000128	-976.96
 | |
| Customer#000000130	5083.58
 | |
| Customer#000000131	8605.53
 | |
| Customer#000000133	2324.67
 | |
| Customer#000000134	4618.9
 | |
| Customer#000000136	-832.39
 | |
| Customer#000000137	7848.3
 | |
| Customer#000000139	7907.78
 | |
| Customer#000000140	9973.15
 | |
| Customer#000000142	2219.81
 | |
| Customer#000000143	2196.5
 | |
| Customer#000000145	9758.93
 | |
| Customer#000000148	2145.6
 | |
| Customer#000000149	8969.65
 | |
| execute stmt using -(@a1+@a2);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	711.56
 | |
| Customer#000000002	121.65
 | |
| Customer#000000005	794.47
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000010	2753.54
 | |
| Customer#000000011	-272.6
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000014	5266.3
 | |
| Customer#000000016	4681.03
 | |
| Customer#000000017	6.34
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000022	591.98
 | |
| Customer#000000023	3332.02
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000028	1007.1799999999998
 | |
| Customer#000000029	7618.27
 | |
| Customer#000000031	5236.89
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000034	8589.7
 | |
| Customer#000000035	1228.24
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000038	6345.11
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000041	270.95
 | |
| Customer#000000043	9904.28
 | |
| Customer#000000044	7315.94
 | |
| Customer#000000046	5744.59
 | |
| Customer#000000047	274.58
 | |
| Customer#000000049	4573.94
 | |
| Customer#000000052	5630.28
 | |
| Customer#000000053	4113.64
 | |
| Customer#000000055	4572.11
 | |
| Customer#000000056	6530.86
 | |
| Customer#000000058	6478.46
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000062	595.61
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000065	8795.16
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000070	4867.52
 | |
| Customer#000000071	-611.19
 | |
| Customer#000000073	4288.5
 | |
| Customer#000000074	2764.43
 | |
| Customer#000000076	5745.33
 | |
| Customer#000000079	5121.28
 | |
| Customer#000000080	7383.53
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000083	6463.51
 | |
| Customer#000000085	3386.64
 | |
| Customer#000000086	3306.32
 | |
| Customer#000000088	8031.44
 | |
| Customer#000000089	1530.76
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000095	5327.38
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000098	-551.37
 | |
| Customer#000000100	9889.89
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000104	-588.38
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000107	2514.15
 | |
| Customer#000000109	-716.1
 | |
| Customer#000000110	7462.99
 | |
| Customer#000000112	2953.35
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000116	8403.99
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000127	9280.71
 | |
| Customer#000000128	-986.96
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000131	8595.53
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000134	4608.9
 | |
| Customer#000000136	-842.39
 | |
| Customer#000000137	7838.3
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000140	9963.15
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000143	2186.5
 | |
| Customer#000000145	9748.93
 | |
| Customer#000000148	2135.6
 | |
| Customer#000000149	8959.65
 | |
| deallocate prepare stmt;
 | |
| # Materialization SJM PS
 | |
| # ======================
 | |
| prepare stmt from "
 | |
| update customer set c_acctbal = c_acctbal+? where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| ";
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| c_name	c_acctbal
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000056	6530.86
 | |
| set @a1=-2;
 | |
| execute stmt using @a1;
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| c_name	c_acctbal
 | |
| Customer#000000013	3855.34
 | |
| Customer#000000032	3469.53
 | |
| Customer#000000037	-919.75
 | |
| Customer#000000118	3580.37
 | |
| Customer#000000056	6528.86
 | |
| set @a2=-1;
 | |
| execute stmt using @a2;
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| c_name	c_acctbal
 | |
| Customer#000000013	3854.34
 | |
| Customer#000000032	3468.53
 | |
| Customer#000000037	-920.75
 | |
| Customer#000000118	3579.37
 | |
| Customer#000000056	6527.86
 | |
| execute stmt using -(@a1+@a2);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| c_name	c_acctbal
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000056	6530.86
 | |
| deallocate prepare stmt;
 | |
| # Pullout SP
 | |
| # ==========
 | |
| create procedure p(d int)
 | |
| update orders set o_totalprice = o_totalprice+d where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| o_orderkey	o_totalprice
 | |
| 644	201268.06
 | |
| 2880	145761.99
 | |
| 3142	16030.15
 | |
| 5382	138423.03
 | |
| 5095	184583.99
 | |
| 737	12984.85
 | |
| 1729	12137.76
 | |
| 5121	150334.57
 | |
| call p(-10);
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| o_orderkey	o_totalprice
 | |
| 644	201258.06
 | |
| 2880	145751.99
 | |
| 3142	16020.15
 | |
| 5382	138413.03
 | |
| 5095	184573.99
 | |
| 737	12974.85
 | |
| 1729	12127.76
 | |
| 5121	150324.57
 | |
| call p(-20);
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| o_orderkey	o_totalprice
 | |
| 644	201238.06
 | |
| 2880	145731.99
 | |
| 3142	16000.15
 | |
| 5382	138393.03
 | |
| 5095	184553.99
 | |
| 737	12954.85
 | |
| 1729	12107.76
 | |
| 5121	150304.57
 | |
| call p(10+20);
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (select n_nationkey from nation
 | |
| where n_name='PERU'));
 | |
| o_orderkey	o_totalprice
 | |
| 644	201268.06
 | |
| 2880	145761.99
 | |
| 3142	16030.15
 | |
| 5382	138423.03
 | |
| 5095	184583.99
 | |
| 737	12984.85
 | |
| 1729	12137.76
 | |
| 5121	150334.57
 | |
| drop procedure p;
 | |
| # FirstMatch SP
 | |
| # =============
 | |
| set optimizer_switch='materialization=off';
 | |
| create procedure p(d int)
 | |
| update customer set c_acctbal = c_acctbal+d where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000017	6.34
 | |
| Customer#000000047	274.58
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000022	591.98
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000028	1007.1799999999998
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000077	1738.87
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000124	1842.49
 | |
| Customer#000000127	9280.71
 | |
| call p(5);
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000059	3463.6
 | |
| Customer#000000106	3293.42
 | |
| Customer#000000017	11.34
 | |
| Customer#000000047	279.58
 | |
| Customer#000000092	1187.91
 | |
| Customer#000000101	7475.96
 | |
| Customer#000000022	596.98
 | |
| Customer#000000040	1340.3
 | |
| Customer#000000064	-641.64
 | |
| Customer#000000122	7870.46
 | |
| Customer#000000028	1012.1799999999998
 | |
| Customer#000000037	-912.75
 | |
| Customer#000000091	4648.14
 | |
| Customer#000000115	7513.92
 | |
| Customer#000000067	8171.59
 | |
| Customer#000000094	5505.11
 | |
| Customer#000000103	2762.45
 | |
| Customer#000000130	5078.58
 | |
| Customer#000000139	7902.78
 | |
| Customer#000000142	2214.81
 | |
| Customer#000000025	7138.7
 | |
| Customer#000000008	6824.74
 | |
| Customer#000000061	1541.24
 | |
| Customer#000000077	1743.87
 | |
| Customer#000000097	2169.48
 | |
| Customer#000000121	6433.32
 | |
| Customer#000000133	2319.67
 | |
| Customer#000000007	9566.95
 | |
| Customer#000000019	8919.71
 | |
| Customer#000000082	9473.34
 | |
| Customer#000000124	1847.49
 | |
| Customer#000000127	9285.71
 | |
| call p(15);
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000059	3478.6
 | |
| Customer#000000106	3308.42
 | |
| Customer#000000017	26.34
 | |
| Customer#000000047	294.58
 | |
| Customer#000000092	1202.91
 | |
| Customer#000000101	7490.96
 | |
| Customer#000000022	611.98
 | |
| Customer#000000040	1355.3
 | |
| Customer#000000064	-626.64
 | |
| Customer#000000122	7885.46
 | |
| Customer#000000028	1027.1799999999998
 | |
| Customer#000000037	-897.75
 | |
| Customer#000000091	4663.14
 | |
| Customer#000000115	7528.92
 | |
| Customer#000000067	8186.59
 | |
| Customer#000000094	5520.11
 | |
| Customer#000000103	2777.45
 | |
| Customer#000000130	5093.58
 | |
| Customer#000000139	7917.78
 | |
| Customer#000000142	2229.81
 | |
| Customer#000000025	7153.7
 | |
| Customer#000000008	6839.74
 | |
| Customer#000000061	1556.24
 | |
| Customer#000000077	1758.87
 | |
| Customer#000000097	2184.48
 | |
| Customer#000000121	6448.32
 | |
| Customer#000000133	2334.67
 | |
| Customer#000000007	9581.95
 | |
| Customer#000000019	8934.71
 | |
| Customer#000000082	9488.34
 | |
| Customer#000000124	1862.49
 | |
| Customer#000000127	9300.71
 | |
| call p(-(5+15));
 | |
| select c_name, c_acctbal from customer where c_nationkey in (select n_nationkey from nation
 | |
| where n_regionkey in (1,2))
 | |
| and
 | |
| c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-10-09' and '1993-06-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000017	6.34
 | |
| Customer#000000047	274.58
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000022	591.98
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000028	1007.1799999999998
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000077	1738.87
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000124	1842.49
 | |
| Customer#000000127	9280.71
 | |
| drop procedure p;
 | |
| set optimizer_switch='materialization=default';
 | |
| # Materialization SP
 | |
| # ==================
 | |
| create procedure p(d int)
 | |
| update customer set c_acctbal = c_acctbal+d where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	711.56
 | |
| Customer#000000002	121.65
 | |
| Customer#000000005	794.47
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000010	2753.54
 | |
| Customer#000000011	-272.6
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000014	5266.3
 | |
| Customer#000000016	4681.03
 | |
| Customer#000000017	6.34
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000022	591.98
 | |
| Customer#000000023	3332.02
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000028	1007.1799999999998
 | |
| Customer#000000029	7618.27
 | |
| Customer#000000031	5236.89
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000034	8589.7
 | |
| Customer#000000035	1228.24
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000038	6345.11
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000041	270.95
 | |
| Customer#000000043	9904.28
 | |
| Customer#000000044	7315.94
 | |
| Customer#000000046	5744.59
 | |
| Customer#000000047	274.58
 | |
| Customer#000000049	4573.94
 | |
| Customer#000000052	5630.28
 | |
| Customer#000000053	4113.64
 | |
| Customer#000000055	4572.11
 | |
| Customer#000000056	6530.86
 | |
| Customer#000000058	6478.46
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000062	595.61
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000065	8795.16
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000070	4867.52
 | |
| Customer#000000071	-611.19
 | |
| Customer#000000073	4288.5
 | |
| Customer#000000074	2764.43
 | |
| Customer#000000076	5745.33
 | |
| Customer#000000079	5121.28
 | |
| Customer#000000080	7383.53
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000083	6463.51
 | |
| Customer#000000085	3386.64
 | |
| Customer#000000086	3306.32
 | |
| Customer#000000088	8031.44
 | |
| Customer#000000089	1530.76
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000095	5327.38
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000098	-551.37
 | |
| Customer#000000100	9889.89
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000104	-588.38
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000107	2514.15
 | |
| Customer#000000109	-716.1
 | |
| Customer#000000110	7462.99
 | |
| Customer#000000112	2953.35
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000116	8403.99
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000127	9280.71
 | |
| Customer#000000128	-986.96
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000131	8595.53
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000134	4608.9
 | |
| Customer#000000136	-842.39
 | |
| Customer#000000137	7838.3
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000140	9963.15
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000143	2186.5
 | |
| Customer#000000145	9748.93
 | |
| Customer#000000148	2135.6
 | |
| Customer#000000149	8959.65
 | |
| call p(3);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	714.56
 | |
| Customer#000000002	124.65
 | |
| Customer#000000005	797.47
 | |
| Customer#000000007	9564.95
 | |
| Customer#000000008	6822.74
 | |
| Customer#000000010	2756.54
 | |
| Customer#000000011	-269.6
 | |
| Customer#000000013	3860.34
 | |
| Customer#000000014	5269.3
 | |
| Customer#000000016	4684.03
 | |
| Customer#000000017	9.34
 | |
| Customer#000000019	8917.71
 | |
| Customer#000000022	594.98
 | |
| Customer#000000023	3335.02
 | |
| Customer#000000025	7136.7
 | |
| Customer#000000028	1010.1799999999998
 | |
| Customer#000000029	7621.27
 | |
| Customer#000000031	5239.89
 | |
| Customer#000000032	3474.53
 | |
| Customer#000000034	8592.7
 | |
| Customer#000000035	1231.24
 | |
| Customer#000000037	-914.75
 | |
| Customer#000000038	6348.11
 | |
| Customer#000000040	1338.3
 | |
| Customer#000000041	273.95
 | |
| Customer#000000043	9907.28
 | |
| Customer#000000044	7318.94
 | |
| Customer#000000046	5747.59
 | |
| Customer#000000047	277.58
 | |
| Customer#000000049	4576.94
 | |
| Customer#000000052	5633.28
 | |
| Customer#000000053	4116.64
 | |
| Customer#000000055	4575.11
 | |
| Customer#000000056	6533.86
 | |
| Customer#000000058	6481.46
 | |
| Customer#000000059	3461.6
 | |
| Customer#000000061	1539.24
 | |
| Customer#000000062	598.61
 | |
| Customer#000000064	-643.64
 | |
| Customer#000000065	8798.16
 | |
| Customer#000000067	8169.59
 | |
| Customer#000000070	4870.52
 | |
| Customer#000000071	-608.19
 | |
| Customer#000000073	4291.5
 | |
| Customer#000000074	2767.43
 | |
| Customer#000000076	5748.33
 | |
| Customer#000000079	5124.28
 | |
| Customer#000000080	7386.53
 | |
| Customer#000000082	9471.34
 | |
| Customer#000000083	6466.51
 | |
| Customer#000000085	3389.64
 | |
| Customer#000000086	3309.32
 | |
| Customer#000000088	8034.44
 | |
| Customer#000000089	1533.76
 | |
| Customer#000000091	4646.14
 | |
| Customer#000000092	1185.91
 | |
| Customer#000000094	5503.11
 | |
| Customer#000000095	5330.38
 | |
| Customer#000000097	2167.48
 | |
| Customer#000000098	-548.37
 | |
| Customer#000000100	9892.89
 | |
| Customer#000000101	7473.96
 | |
| Customer#000000103	2760.45
 | |
| Customer#000000104	-585.38
 | |
| Customer#000000106	3291.42
 | |
| Customer#000000107	2517.15
 | |
| Customer#000000109	-713.1
 | |
| Customer#000000110	7465.99
 | |
| Customer#000000112	2956.35
 | |
| Customer#000000115	7511.92
 | |
| Customer#000000116	8406.99
 | |
| Customer#000000118	3585.37
 | |
| Customer#000000121	6431.32
 | |
| Customer#000000122	7868.46
 | |
| Customer#000000127	9283.71
 | |
| Customer#000000128	-983.96
 | |
| Customer#000000130	5076.58
 | |
| Customer#000000131	8598.53
 | |
| Customer#000000133	2317.67
 | |
| Customer#000000134	4611.9
 | |
| Customer#000000136	-839.39
 | |
| Customer#000000137	7841.3
 | |
| Customer#000000139	7900.78
 | |
| Customer#000000140	9966.15
 | |
| Customer#000000142	2212.81
 | |
| Customer#000000143	2189.5
 | |
| Customer#000000145	9751.93
 | |
| Customer#000000148	2138.6
 | |
| Customer#000000149	8962.65
 | |
| call p(7);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	721.56
 | |
| Customer#000000002	131.65
 | |
| Customer#000000005	804.47
 | |
| Customer#000000007	9571.95
 | |
| Customer#000000008	6829.74
 | |
| Customer#000000010	2763.54
 | |
| Customer#000000011	-262.6
 | |
| Customer#000000013	3867.34
 | |
| Customer#000000014	5276.3
 | |
| Customer#000000016	4691.03
 | |
| Customer#000000017	16.34
 | |
| Customer#000000019	8924.71
 | |
| Customer#000000022	601.98
 | |
| Customer#000000023	3342.02
 | |
| Customer#000000025	7143.7
 | |
| Customer#000000028	1017.1799999999998
 | |
| Customer#000000029	7628.27
 | |
| Customer#000000031	5246.89
 | |
| Customer#000000032	3481.53
 | |
| Customer#000000034	8599.7
 | |
| Customer#000000035	1238.24
 | |
| Customer#000000037	-907.75
 | |
| Customer#000000038	6355.11
 | |
| Customer#000000040	1345.3
 | |
| Customer#000000041	280.95
 | |
| Customer#000000043	9914.28
 | |
| Customer#000000044	7325.94
 | |
| Customer#000000046	5754.59
 | |
| Customer#000000047	284.58
 | |
| Customer#000000049	4583.94
 | |
| Customer#000000052	5640.28
 | |
| Customer#000000053	4123.64
 | |
| Customer#000000055	4582.11
 | |
| Customer#000000056	6540.86
 | |
| Customer#000000058	6488.46
 | |
| Customer#000000059	3468.6
 | |
| Customer#000000061	1546.24
 | |
| Customer#000000062	605.61
 | |
| Customer#000000064	-636.64
 | |
| Customer#000000065	8805.16
 | |
| Customer#000000067	8176.59
 | |
| Customer#000000070	4877.52
 | |
| Customer#000000071	-601.19
 | |
| Customer#000000073	4298.5
 | |
| Customer#000000074	2774.43
 | |
| Customer#000000076	5755.33
 | |
| Customer#000000079	5131.28
 | |
| Customer#000000080	7393.53
 | |
| Customer#000000082	9478.34
 | |
| Customer#000000083	6473.51
 | |
| Customer#000000085	3396.64
 | |
| Customer#000000086	3316.32
 | |
| Customer#000000088	8041.44
 | |
| Customer#000000089	1540.76
 | |
| Customer#000000091	4653.14
 | |
| Customer#000000092	1192.91
 | |
| Customer#000000094	5510.11
 | |
| Customer#000000095	5337.38
 | |
| Customer#000000097	2174.48
 | |
| Customer#000000098	-541.37
 | |
| Customer#000000100	9899.89
 | |
| Customer#000000101	7480.96
 | |
| Customer#000000103	2767.45
 | |
| Customer#000000104	-578.38
 | |
| Customer#000000106	3298.42
 | |
| Customer#000000107	2524.15
 | |
| Customer#000000109	-706.1
 | |
| Customer#000000110	7472.99
 | |
| Customer#000000112	2963.35
 | |
| Customer#000000115	7518.92
 | |
| Customer#000000116	8413.99
 | |
| Customer#000000118	3592.37
 | |
| Customer#000000121	6438.32
 | |
| Customer#000000122	7875.46
 | |
| Customer#000000127	9290.71
 | |
| Customer#000000128	-976.96
 | |
| Customer#000000130	5083.58
 | |
| Customer#000000131	8605.53
 | |
| Customer#000000133	2324.67
 | |
| Customer#000000134	4618.9
 | |
| Customer#000000136	-832.39
 | |
| Customer#000000137	7848.3
 | |
| Customer#000000139	7907.78
 | |
| Customer#000000140	9973.15
 | |
| Customer#000000142	2219.81
 | |
| Customer#000000143	2196.5
 | |
| Customer#000000145	9758.93
 | |
| Customer#000000148	2145.6
 | |
| Customer#000000149	8969.65
 | |
| call p(-(3+7));
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1993-03-08');
 | |
| c_name	c_acctbal
 | |
| Customer#000000001	711.56
 | |
| Customer#000000002	121.65
 | |
| Customer#000000005	794.47
 | |
| Customer#000000007	9561.95
 | |
| Customer#000000008	6819.74
 | |
| Customer#000000010	2753.54
 | |
| Customer#000000011	-272.6
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000014	5266.3
 | |
| Customer#000000016	4681.03
 | |
| Customer#000000017	6.34
 | |
| Customer#000000019	8914.71
 | |
| Customer#000000022	591.98
 | |
| Customer#000000023	3332.02
 | |
| Customer#000000025	7133.7
 | |
| Customer#000000028	1007.1799999999998
 | |
| Customer#000000029	7618.27
 | |
| Customer#000000031	5236.89
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000034	8589.7
 | |
| Customer#000000035	1228.24
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000038	6345.11
 | |
| Customer#000000040	1335.3
 | |
| Customer#000000041	270.95
 | |
| Customer#000000043	9904.28
 | |
| Customer#000000044	7315.94
 | |
| Customer#000000046	5744.59
 | |
| Customer#000000047	274.58
 | |
| Customer#000000049	4573.94
 | |
| Customer#000000052	5630.28
 | |
| Customer#000000053	4113.64
 | |
| Customer#000000055	4572.11
 | |
| Customer#000000056	6530.86
 | |
| Customer#000000058	6478.46
 | |
| Customer#000000059	3458.6
 | |
| Customer#000000061	1536.24
 | |
| Customer#000000062	595.61
 | |
| Customer#000000064	-646.64
 | |
| Customer#000000065	8795.16
 | |
| Customer#000000067	8166.59
 | |
| Customer#000000070	4867.52
 | |
| Customer#000000071	-611.19
 | |
| Customer#000000073	4288.5
 | |
| Customer#000000074	2764.43
 | |
| Customer#000000076	5745.33
 | |
| Customer#000000079	5121.28
 | |
| Customer#000000080	7383.53
 | |
| Customer#000000082	9468.34
 | |
| Customer#000000083	6463.51
 | |
| Customer#000000085	3386.64
 | |
| Customer#000000086	3306.32
 | |
| Customer#000000088	8031.44
 | |
| Customer#000000089	1530.76
 | |
| Customer#000000091	4643.14
 | |
| Customer#000000092	1182.91
 | |
| Customer#000000094	5500.11
 | |
| Customer#000000095	5327.38
 | |
| Customer#000000097	2164.48
 | |
| Customer#000000098	-551.37
 | |
| Customer#000000100	9889.89
 | |
| Customer#000000101	7470.96
 | |
| Customer#000000103	2757.45
 | |
| Customer#000000104	-588.38
 | |
| Customer#000000106	3288.42
 | |
| Customer#000000107	2514.15
 | |
| Customer#000000109	-716.1
 | |
| Customer#000000110	7462.99
 | |
| Customer#000000112	2953.35
 | |
| Customer#000000115	7508.92
 | |
| Customer#000000116	8403.99
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000121	6428.32
 | |
| Customer#000000122	7865.46
 | |
| Customer#000000127	9280.71
 | |
| Customer#000000128	-986.96
 | |
| Customer#000000130	5073.58
 | |
| Customer#000000131	8595.53
 | |
| Customer#000000133	2314.67
 | |
| Customer#000000134	4608.9
 | |
| Customer#000000136	-842.39
 | |
| Customer#000000137	7838.3
 | |
| Customer#000000139	7897.78
 | |
| Customer#000000140	9963.15
 | |
| Customer#000000142	2209.81
 | |
| Customer#000000143	2186.5
 | |
| Customer#000000145	9748.93
 | |
| Customer#000000148	2135.6
 | |
| Customer#000000149	8959.65
 | |
| drop procedure p;
 | |
| # Materialization SJM SP
 | |
| # ======================
 | |
| create procedure p(d int)
 | |
| update customer set c_acctbal = c_acctbal+d where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| c_name	c_acctbal
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000056	6530.86
 | |
| call p(-1);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| c_name	c_acctbal
 | |
| Customer#000000013	3856.34
 | |
| Customer#000000032	3470.53
 | |
| Customer#000000037	-918.75
 | |
| Customer#000000118	3581.37
 | |
| Customer#000000056	6529.86
 | |
| call p(-2);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| c_name	c_acctbal
 | |
| Customer#000000013	3854.34
 | |
| Customer#000000032	3468.53
 | |
| Customer#000000037	-920.75
 | |
| Customer#000000118	3579.37
 | |
| Customer#000000056	6527.86
 | |
| call p(1+2);
 | |
| select c_name, c_acctbal from customer where c_custkey in (select o_custkey from orders
 | |
| where o_orderDATE between '1992-01-09' and '1992-03-08'
 | |
|                       group by o_custkey having count(o_custkey) > 1);
 | |
| c_name	c_acctbal
 | |
| Customer#000000013	3857.34
 | |
| Customer#000000032	3471.53
 | |
| Customer#000000037	-917.75
 | |
| Customer#000000118	3582.37
 | |
| Customer#000000056	6530.86
 | |
| drop procedure p;
 | |
| # Checking limitations
 | |
| # ====================
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (1,2));
 | |
| o_orderkey	o_totalprice
 | |
| 1221	117397.16
 | |
| 324	26868.85
 | |
| 1856	189361.42
 | |
| 1344	43809.37
 | |
| 1925	146382.71
 | |
| 3139	40975.96
 | |
| 4903	34363.63
 | |
| 5607	24660.06
 | |
| # Should not use semi-join conversion because has ORDER BY ... LIMIT
 | |
| explain
 | |
| update orders set o_totalprice = o_totalprice-50 where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (1,2))
 | |
| order by o_totalprice limit 500;
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	orders	range	i_o_orderdate	i_o_orderdate	4	NULL	108	Using where; Using filesort
 | |
| 2	DEPENDENT SUBQUERY	customer	unique_subquery	PRIMARY,i_c_nationkey	PRIMARY	4	func	1	Using where
 | |
| update orders set o_totalprice = o_totalprice-50 where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (1,2))
 | |
| order by o_totalprice limit 500;
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (1,2));
 | |
| o_orderkey	o_totalprice
 | |
| 1221	117347.16
 | |
| 324	26818.85
 | |
| 1856	189311.42
 | |
| 1344	43759.37
 | |
| 1925	146332.71
 | |
| 3139	40925.96
 | |
| 4903	34313.63
 | |
| 5607	24610.06
 | |
| update orders set o_totalprice = o_totalprice+50 where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (1,2))
 | |
| order by o_totalprice limit 500;
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (1,2));
 | |
| o_orderkey	o_totalprice
 | |
| 1221	117397.16
 | |
| 324	26868.85
 | |
| 1856	189361.42
 | |
| 1344	43809.37
 | |
| 1925	146382.71
 | |
| 3139	40975.96
 | |
| 4903	34363.63
 | |
| 5607	24660.06
 | |
| # Should use semi-join converion
 | |
| explain
 | |
| update orders set o_totalprice = o_totalprice-50 where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (1,2));
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	customer	range	PRIMARY,i_c_nationkey	i_c_nationkey	5	NULL	15	Using index condition
 | |
| 1	PRIMARY	orders	ref|filter	i_o_orderdate,i_o_custkey	i_o_custkey|i_o_orderdate	5|4	dbt3_s001.customer.c_custkey	15 (7%)	Using where; Using rowid filter
 | |
| update orders set o_totalprice = o_totalprice-50 where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (1,2));
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (1,2));
 | |
| o_orderkey	o_totalprice
 | |
| 1221	117347.16
 | |
| 324	26818.85
 | |
| 1856	189311.42
 | |
| 1344	43759.37
 | |
| 1925	146332.71
 | |
| 3139	40925.96
 | |
| 4903	34313.63
 | |
| 5607	24610.06
 | |
| update orders set o_totalprice = o_totalprice+50 where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (1,2));
 | |
| select o_orderkey, o_totalprice from orders where o_orderDATE between '1992-01-01' and '1992-06-30' and
 | |
| o_custkey in (select c_custkey from customer
 | |
| where c_nationkey in (1,2));
 | |
| o_orderkey	o_totalprice
 | |
| 1221	117397.16
 | |
| 324	26868.85
 | |
| 1856	189361.42
 | |
| 1344	43809.37
 | |
| 1925	146382.71
 | |
| 3139	40975.96
 | |
| 4903	34363.63
 | |
| 5607	24660.06
 | |
| CREATE TABLE partsupp_small (
 | |
| ps_partkey int(11) NOT NULL DEFAULT '0',
 | |
| ps_suppkey int(11) NOT NULL DEFAULT '0',
 | |
| ps_availqty int(11) DEFAULT NULL,
 | |
| ps_supplycost double DEFAULT NULL,
 | |
| ps_comment varchar(199) DEFAULT NULL,
 | |
| PRIMARY KEY (ps_partkey,ps_suppkey),
 | |
| KEY i_ps_partkey (ps_partkey),
 | |
| KEY i_ps_suppkey (ps_suppkey)
 | |
| );
 | |
| create index i_ps_sup_part on partsupp_small(ps_suppkey, ps_partkey);
 | |
| insert into partsupp_small select * from partsupp where ps_partkey <50;
 | |
| analyze table partsupp_small  persistent for all;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| dbt3_s001.partsupp_small	analyze	status	Engine-independent statistics collected
 | |
| dbt3_s001.partsupp_small	analyze	status	OK
 | |
| # LooseScan
 | |
| # =========
 | |
| explain
 | |
| select count(*) from lineitem where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	partsupp_small	index	PRIMARY,i_ps_partkey,i_ps_suppkey,i_ps_sup_part	i_ps_sup_part	8	NULL	176	Using where; Using index; LooseScan
 | |
| 1	PRIMARY	lineitem	ref	i_l_suppkey	i_l_suppkey	5	dbt3_s001.partsupp_small.ps_suppkey	600	Using index
 | |
| explain format=json
 | |
| select count(*) from lineitem where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": "COST_REPLACED",
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "partsupp_small",
 | |
|           "access_type": "index",
 | |
|           "possible_keys": [
 | |
|             "PRIMARY",
 | |
|             "i_ps_partkey",
 | |
|             "i_ps_suppkey",
 | |
|             "i_ps_sup_part"
 | |
|           ],
 | |
|           "key": "i_ps_sup_part",
 | |
|           "key_length": "8",
 | |
|           "used_key_parts": ["ps_suppkey", "ps_partkey"],
 | |
|           "loops": 1,
 | |
|           "rows": 176,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 5.113636494,
 | |
|           "attached_condition": "partsupp_small.ps_partkey in (1,2,3)",
 | |
|           "using_index": true,
 | |
|           "loose_scan": true
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "lineitem",
 | |
|           "access_type": "ref",
 | |
|           "possible_keys": ["i_l_suppkey"],
 | |
|           "key": "i_l_suppkey",
 | |
|           "key_length": "5",
 | |
|           "used_key_parts": ["l_suppkey"],
 | |
|           "ref": ["dbt3_s001.partsupp_small.ps_suppkey"],
 | |
|           "loops": 9,
 | |
|           "rows": 600,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 11.11111069,
 | |
|           "using_index": true
 | |
|         }
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| select count(*) from lineitem where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| count(*)
 | |
| 5373
 | |
| select  5373 as count, 136458704.22 as old_sum;
 | |
| count	old_sum
 | |
| 5373	136458704.22
 | |
| explain
 | |
| update  lineitem set l_extendedprice=l_extendedprice+10 where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	lineitem	ALL	i_l_suppkey	NULL	NULL	NULL	6005	
 | |
| 1	PRIMARY	<subquery2>	eq_ref	distinct_key	distinct_key	4	func	1	
 | |
| 2	MATERIALIZED	partsupp_small	range	PRIMARY,i_ps_partkey,i_ps_suppkey,i_ps_sup_part	PRIMARY	4	NULL	9	Using where; Using index
 | |
| explain format=json
 | |
| update  lineitem set l_extendedprice=l_extendedprice+10 where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": "COST_REPLACED",
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "lineitem",
 | |
|           "access_type": "ALL",
 | |
|           "possible_keys": ["i_l_suppkey"],
 | |
|           "loops": 1,
 | |
|           "rows": 6005,
 | |
|           "cost": "COST_REPLACED",
 | |
|           "filtered": 100
 | |
|         }
 | |
|       },
 | |
|       {
 | |
|         "table": {
 | |
|           "table_name": "<subquery2>",
 | |
|           "access_type": "eq_ref",
 | |
|           "possible_keys": ["distinct_key"],
 | |
|           "key": "distinct_key",
 | |
|           "key_length": "4",
 | |
|           "used_key_parts": ["ps_suppkey"],
 | |
|           "ref": ["func"],
 | |
|           "rows": 1,
 | |
|           "filtered": 100,
 | |
|           "materialized": {
 | |
|             "unique": 1,
 | |
|             "query_block": {
 | |
|               "select_id": 2,
 | |
|               "nested_loop": [
 | |
|                 {
 | |
|                   "table": {
 | |
|                     "table_name": "partsupp_small",
 | |
|                     "access_type": "range",
 | |
|                     "possible_keys": [
 | |
|                       "PRIMARY",
 | |
|                       "i_ps_partkey",
 | |
|                       "i_ps_suppkey",
 | |
|                       "i_ps_sup_part"
 | |
|                     ],
 | |
|                     "key": "PRIMARY",
 | |
|                     "key_length": "4",
 | |
|                     "used_key_parts": ["ps_partkey"],
 | |
|                     "loops": 1,
 | |
|                     "rows": 9,
 | |
|                     "cost": "COST_REPLACED",
 | |
|                     "filtered": 100,
 | |
|                     "attached_condition": "partsupp_small.ps_partkey in (1,2,3)",
 | |
|                     "using_index": true
 | |
|                   }
 | |
|                 }
 | |
|               ]
 | |
|             }
 | |
|           }
 | |
|         }
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| update  lineitem set l_extendedprice=l_extendedprice+10 where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| select ROUND(sum(l_extendedprice),2), 5373 as count,
 | |
| (136458704.22+10*5373) as 'old_sum+10*count'
 | |
|         from lineitem where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum+10*count
 | |
| 136512434.22	5373	136512434.22
 | |
| update  lineitem set l_extendedprice=l_extendedprice-10 where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| select  ROUND(sum(l_extendedprice),2), 5373 as count,
 | |
| 136458704.22 as old_sum from lineitem where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum
 | |
| 136458704.22	5373	136458704.22
 | |
| # LooseScan PS
 | |
| # ============
 | |
| prepare stmt from "
 | |
| update  lineitem set l_extendedprice=l_extendedprice+? where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| ";
 | |
| select  5373 as count, 136458704.22 as old_sum;
 | |
| count	old_sum
 | |
| 5373	136458704.22
 | |
| set @a1=20;
 | |
| execute stmt using @a1;
 | |
| select ROUND(sum(l_extendedprice),2), 5373 as count,
 | |
| (136458704.22+20*5373) as 'old_sum+20*count'
 | |
|         from lineitem where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum+20*count
 | |
| 136566164.22	5373	136566164.22
 | |
| set @a2=10;
 | |
| execute stmt using @a2;
 | |
| select ROUND(sum(l_extendedprice),2), 5373 as count,
 | |
| (136458704.22+30*5373) as 'old_sum+30*count'
 | |
|         from lineitem where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum+30*count
 | |
| 136619894.22	5373	136619894.22
 | |
| execute stmt using -(@a1+@a2);
 | |
| select  ROUND(sum(l_extendedprice),2), 5373 as count,
 | |
| 136458704.22 as old_sum from lineitem where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum
 | |
| 136458704.22	5373	136458704.22
 | |
| deallocate prepare stmt;
 | |
| # LooseScan SP
 | |
| # ============
 | |
| create procedure p(d int)
 | |
| update  lineitem set l_extendedprice=l_extendedprice+d where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| select  5373 as count, 136458704.22 as old_sum;
 | |
| count	old_sum
 | |
| 5373	136458704.22
 | |
| call p(10);
 | |
| select ROUND(sum(l_extendedprice),2), 5373 as count,
 | |
| (136458704.22+10*5373) as 'old_sum+10*count'
 | |
|         from lineitem where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum+10*count
 | |
| 136512434.22	5373	136512434.22
 | |
| call p(20);
 | |
| select ROUND(sum(l_extendedprice),2), 5373 as count,
 | |
| (136458704.22+30*5373) as 'old_sum+30*count'
 | |
|         from lineitem where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum+30*count
 | |
| 136619894.22	5373	136619894.22
 | |
| call p(-(10+20));
 | |
| select  ROUND(sum(l_extendedprice),2), 5373 as count,
 | |
| 136458704.22 as old_sum from lineitem where l_suppkey in
 | |
| (select ps_suppkey from partsupp_small
 | |
| where ps_partkey in (1,2,3));
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum
 | |
| 136458704.22	5373	136458704.22
 | |
| drop procedure p;
 | |
| # DuplicateWeedout
 | |
| # ================
 | |
| set @tmp_optimizer_switch= @@optimizer_switch;
 | |
| set optimizer_switch='materialization=off';
 | |
| analyze table lineitem;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| dbt3_s001.lineitem	analyze	status	Engine-independent statistics collected
 | |
| dbt3_s001.lineitem	analyze	status	OK
 | |
| analyze table orders;
 | |
| Table	Op	Msg_type	Msg_text
 | |
| dbt3_s001.orders	analyze	status	Engine-independent statistics collected
 | |
| dbt3_s001.orders	analyze	status	OK
 | |
| explain
 | |
| select count(*) from lineitem where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	supplier	range	PRIMARY	PRIMARY	4	NULL	1	Using where; Using index; Start temporary
 | |
| 1	PRIMARY	partsupp_small	ref	PRIMARY,i_ps_partkey,i_ps_suppkey,i_ps_sup_part	i_ps_sup_part	4	dbt3_s001.supplier.s_suppkey	17	Using where; Using index
 | |
| 1	PRIMARY	lineitem	ref	i_l_suppkey_partkey,i_l_partkey	i_l_suppkey_partkey	5	dbt3_s001.partsupp_small.ps_partkey	30	Using index
 | |
| 1	PRIMARY	lineitem	ref	i_l_suppkey_partkey,i_l_partkey	i_l_partkey	5	dbt3_s001.partsupp_small.ps_partkey	30	Using index; End temporary
 | |
| explain format=json
 | |
| select count(*) from lineitem where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": "COST_REPLACED",
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "duplicates_removal": [
 | |
|           {
 | |
|             "table": {
 | |
|               "table_name": "supplier",
 | |
|               "access_type": "range",
 | |
|               "possible_keys": ["PRIMARY"],
 | |
|               "key": "PRIMARY",
 | |
|               "key_length": "4",
 | |
|               "used_key_parts": ["s_suppkey"],
 | |
|               "loops": 1,
 | |
|               "rows": 1,
 | |
|               "cost": "COST_REPLACED",
 | |
|               "filtered": 100,
 | |
|               "attached_condition": "supplier.s_suppkey < 2",
 | |
|               "using_index": true
 | |
|             }
 | |
|           },
 | |
|           {
 | |
|             "table": {
 | |
|               "table_name": "partsupp_small",
 | |
|               "access_type": "ref",
 | |
|               "possible_keys": [
 | |
|                 "PRIMARY",
 | |
|                 "i_ps_partkey",
 | |
|                 "i_ps_suppkey",
 | |
|                 "i_ps_sup_part"
 | |
|               ],
 | |
|               "key": "i_ps_sup_part",
 | |
|               "key_length": "4",
 | |
|               "used_key_parts": ["ps_suppkey"],
 | |
|               "ref": ["dbt3_s001.supplier.s_suppkey"],
 | |
|               "loops": 1,
 | |
|               "rows": 17,
 | |
|               "cost": "COST_REPLACED",
 | |
|               "filtered": 79.54545593,
 | |
|               "attached_condition": "partsupp_small.ps_partkey is not null",
 | |
|               "using_index": true
 | |
|             }
 | |
|           },
 | |
|           {
 | |
|             "table": {
 | |
|               "table_name": "lineitem",
 | |
|               "access_type": "ref",
 | |
|               "possible_keys": ["i_l_suppkey_partkey", "i_l_partkey"],
 | |
|               "key": "i_l_suppkey_partkey",
 | |
|               "key_length": "5",
 | |
|               "used_key_parts": ["l_partkey"],
 | |
|               "ref": ["dbt3_s001.partsupp_small.ps_partkey"],
 | |
|               "loops": 14,
 | |
|               "rows": 30,
 | |
|               "cost": "COST_REPLACED",
 | |
|               "filtered": 100,
 | |
|               "using_index": true
 | |
|             }
 | |
|           },
 | |
|           {
 | |
|             "table": {
 | |
|               "table_name": "lineitem",
 | |
|               "access_type": "ref",
 | |
|               "possible_keys": ["i_l_suppkey_partkey", "i_l_partkey"],
 | |
|               "key": "i_l_partkey",
 | |
|               "key_length": "5",
 | |
|               "used_key_parts": ["l_partkey"],
 | |
|               "ref": ["dbt3_s001.partsupp_small.ps_partkey"],
 | |
|               "loops": 420.35,
 | |
|               "rows": 30,
 | |
|               "cost": "COST_REPLACED",
 | |
|               "filtered": 0.237896994,
 | |
|               "using_index": true
 | |
|             }
 | |
|           }
 | |
|         ]
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| select count(*) from lineitem where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| count(*)
 | |
| 471
 | |
| select  471 as count, 10751458.66 as old_sum;
 | |
| count	old_sum
 | |
| 471	10751458.66
 | |
| explain
 | |
| update  lineitem set l_extendedprice=l_extendedprice+10 where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| id	select_type	table	type	possible_keys	key	key_len	ref	rows	Extra
 | |
| 1	PRIMARY	supplier	range	PRIMARY	PRIMARY	4	NULL	1	Using where; Using index; Start temporary
 | |
| 1	PRIMARY	partsupp_small	ref	PRIMARY,i_ps_partkey,i_ps_suppkey,i_ps_sup_part	i_ps_sup_part	4	dbt3_s001.supplier.s_suppkey	17	Using where; Using index
 | |
| 1	PRIMARY	lineitem	ref	i_l_suppkey_partkey,i_l_partkey	i_l_suppkey_partkey	5	dbt3_s001.partsupp_small.ps_partkey	30	
 | |
| 1	PRIMARY	lineitem	ref	i_l_suppkey_partkey,i_l_partkey	i_l_partkey	5	dbt3_s001.partsupp_small.ps_partkey	30	Using index; End temporary
 | |
| explain format=json
 | |
| update  lineitem set l_extendedprice=l_extendedprice+10 where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| EXPLAIN
 | |
| {
 | |
|   "query_block": {
 | |
|     "select_id": 1,
 | |
|     "cost": "COST_REPLACED",
 | |
|     "nested_loop": [
 | |
|       {
 | |
|         "duplicates_removal": [
 | |
|           {
 | |
|             "table": {
 | |
|               "table_name": "supplier",
 | |
|               "access_type": "range",
 | |
|               "possible_keys": ["PRIMARY"],
 | |
|               "key": "PRIMARY",
 | |
|               "key_length": "4",
 | |
|               "used_key_parts": ["s_suppkey"],
 | |
|               "loops": 1,
 | |
|               "rows": 1,
 | |
|               "cost": "COST_REPLACED",
 | |
|               "filtered": 100,
 | |
|               "attached_condition": "supplier.s_suppkey < 2",
 | |
|               "using_index": true
 | |
|             }
 | |
|           },
 | |
|           {
 | |
|             "table": {
 | |
|               "table_name": "partsupp_small",
 | |
|               "access_type": "ref",
 | |
|               "possible_keys": [
 | |
|                 "PRIMARY",
 | |
|                 "i_ps_partkey",
 | |
|                 "i_ps_suppkey",
 | |
|                 "i_ps_sup_part"
 | |
|               ],
 | |
|               "key": "i_ps_sup_part",
 | |
|               "key_length": "4",
 | |
|               "used_key_parts": ["ps_suppkey"],
 | |
|               "ref": ["dbt3_s001.supplier.s_suppkey"],
 | |
|               "loops": 1,
 | |
|               "rows": 17,
 | |
|               "cost": "COST_REPLACED",
 | |
|               "filtered": 79.54545593,
 | |
|               "attached_condition": "partsupp_small.ps_partkey is not null",
 | |
|               "using_index": true
 | |
|             }
 | |
|           },
 | |
|           {
 | |
|             "table": {
 | |
|               "table_name": "lineitem",
 | |
|               "access_type": "ref",
 | |
|               "possible_keys": ["i_l_suppkey_partkey", "i_l_partkey"],
 | |
|               "key": "i_l_suppkey_partkey",
 | |
|               "key_length": "5",
 | |
|               "used_key_parts": ["l_partkey"],
 | |
|               "ref": ["dbt3_s001.partsupp_small.ps_partkey"],
 | |
|               "loops": 14,
 | |
|               "rows": 30,
 | |
|               "cost": "COST_REPLACED",
 | |
|               "filtered": 100
 | |
|             }
 | |
|           },
 | |
|           {
 | |
|             "table": {
 | |
|               "table_name": "lineitem",
 | |
|               "access_type": "ref",
 | |
|               "possible_keys": ["i_l_suppkey_partkey", "i_l_partkey"],
 | |
|               "key": "i_l_partkey",
 | |
|               "key_length": "5",
 | |
|               "used_key_parts": ["l_partkey"],
 | |
|               "ref": ["dbt3_s001.partsupp_small.ps_partkey"],
 | |
|               "loops": 420.35,
 | |
|               "rows": 30,
 | |
|               "cost": "COST_REPLACED",
 | |
|               "filtered": 0.237896994,
 | |
|               "using_index": true
 | |
|             }
 | |
|           }
 | |
|         ]
 | |
|       }
 | |
|     ]
 | |
|   }
 | |
| }
 | |
| update  lineitem set l_extendedprice=l_extendedprice+10 where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| select ROUND(sum(l_extendedprice),2), 471 as count,
 | |
| (10751458.66+10*471) as 'old_sum+10*count'
 | |
|         from lineitem where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum+10*count
 | |
| 10756168.66	471	10756168.66
 | |
| update  lineitem set l_extendedprice=l_extendedprice-10 where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| select  ROUND(sum(l_extendedprice),2), 471 as count,
 | |
| 10751458.66 as old_sum from lineitem where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum
 | |
| 10751458.66	471	10751458.66
 | |
| # DuplicateWeedout PS
 | |
| # ===================
 | |
| prepare stmt from "
 | |
| update  lineitem set l_extendedprice=l_extendedprice+? where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| ";
 | |
| select  471 as count, 10751458.66 as old_sum;
 | |
| count	old_sum
 | |
| 471	10751458.66
 | |
| set @a1=20;
 | |
| execute stmt using @a1;
 | |
| select ROUND(sum(l_extendedprice),2), 471 as count,
 | |
| (10751458.66+20*471) as 'old_sum+20*count'
 | |
|         from lineitem where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum+20*count
 | |
| 10760878.66	471	10760878.66
 | |
| set @a2=10;
 | |
| execute stmt using @a2;
 | |
| select ROUND(sum(l_extendedprice),2), 471 as count,
 | |
| (10751458.66+30*471) as 'old_sum+30*count'
 | |
|         from lineitem where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum+30*count
 | |
| 10765588.66	471	10765588.66
 | |
| execute stmt using -(@a1+@a2);
 | |
| select  ROUND(sum(l_extendedprice),2), 471 as count,
 | |
| 10751458.66 as old_sum from lineitem where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum
 | |
| 10751458.66	471	10751458.66
 | |
| deallocate prepare stmt;
 | |
| # DuplicateWeedout SP
 | |
| # ===================
 | |
| create procedure p(d int)
 | |
| update  lineitem set l_extendedprice=l_extendedprice+d where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| select  471 as count, 10751458.66 as old_sum;
 | |
| count	old_sum
 | |
| 471	10751458.66
 | |
| call p(10);
 | |
| select ROUND(sum(l_extendedprice),2), 471 as count,
 | |
| (10751458.66+10*471) as 'old_sum+10*count'
 | |
|         from lineitem where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum+10*count
 | |
| 10756168.66	471	10756168.66
 | |
| call p(20);
 | |
| select ROUND(sum(l_extendedprice),2), 471 as count,
 | |
| (10751458.66+30*471) as 'old_sum+30*count'
 | |
|         from lineitem where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum+30*count
 | |
| 10765588.66	471	10765588.66
 | |
| call p(-(10+20));
 | |
| select  ROUND(sum(l_extendedprice),2), 471 as count,
 | |
| 10751458.66 as old_sum from lineitem where l_partkey in (
 | |
| select ps_partkey
 | |
| from partsupp_small join lineitem on ps_partkey=l_partkey
 | |
| where ps_suppkey in (
 | |
| select s_suppkey from supplier  where  s_suppkey < 2
 | |
| )
 | |
| );
 | |
| ROUND(sum(l_extendedprice),2)	count	old_sum
 | |
| 10751458.66	471	10751458.66
 | |
| drop procedure p;
 | |
| set @@optimizer_switch=@tmp_optimizer_switch;
 | |
| drop table partsupp_small;
 | |
| DROP DATABASE dbt3_s001;
 | 
