mirror of
https://github.com/MariaDB/server.git
synced 2025-07-30 16:24:05 +03:00
MDEV-7486: Condition pushdown from HAVING into WHERE
Condition can be pushed from the HAVING clause into the WHERE clause if it depends only on the fields that are used in the GROUP BY list or depends on the fields that are equal to grouping fields. Aggregate functions can't be pushed down. How the pushdown is performed on the example: SELECT t1.a,MAX(t1.b) FROM t1 GROUP BY t1.a HAVING (t1.a>2) AND (MAX(c)>12); => SELECT t1.a,MAX(t1.b) FROM t1 WHERE (t1.a>2) GROUP BY t1.a HAVING (MAX(c)>12); The implementation scheme: 1. Extract the most restrictive condition cond from the HAVING clause of the select that depends only on the fields that are used in the GROUP BY list of the select (directly or indirectly through equalities) 2. Save cond as a condition that can be pushed into the WHERE clause of the select 3. Remove cond from the HAVING clause if it is possible The optimization is implemented in the function st_select_lex::pushdown_from_having_into_where(). New test file having_cond_pushdown.test is created.
This commit is contained in:
committed by
Igor Babaev
parent
790b6f5ae2
commit
7a77b221f1
@ -234,7 +234,7 @@
|
||||
#define OPTIMIZER_SWITCH_SPLIT_MATERIALIZED (1ULL << 31)
|
||||
#define OPTIMIZER_SWITCH_COND_PUSHDOWN_FOR_SUBQUERY (1ULL << 32)
|
||||
#define OPTIMIZER_SWITCH_USE_ROWID_FILTER (1ULL << 33)
|
||||
|
||||
#define OPTIMIZER_SWITCH_COND_PUSHDOWN_FROM_HAVING (1ULL << 34)
|
||||
|
||||
#define OPTIMIZER_SWITCH_DEFAULT (OPTIMIZER_SWITCH_INDEX_MERGE | \
|
||||
OPTIMIZER_SWITCH_INDEX_MERGE_UNION | \
|
||||
@ -263,7 +263,8 @@
|
||||
OPTIMIZER_SWITCH_COND_PUSHDOWN_FOR_DERIVED | \
|
||||
OPTIMIZER_SWITCH_SPLIT_MATERIALIZED | \
|
||||
OPTIMIZER_SWITCH_COND_PUSHDOWN_FOR_SUBQUERY |\
|
||||
OPTIMIZER_SWITCH_USE_ROWID_FILTER)
|
||||
OPTIMIZER_SWITCH_USE_ROWID_FILTER | \
|
||||
OPTIMIZER_SWITCH_COND_PUSHDOWN_FROM_HAVING)
|
||||
|
||||
/*
|
||||
Replication uses 8 bytes to store SQL_MODE in the binary log. The day you
|
||||
|
Reference in New Issue
Block a user