diff options
author | Tor Didriksen <tor.didriksen@oracle.com> | 2011-05-05 08:13:22 +0200 |
---|---|---|
committer | Tor Didriksen <tor.didriksen@oracle.com> | 2011-05-05 08:13:22 +0200 |
commit | 294fb44d67ff1b12e11b7f771d5260ed2b1b97fb (patch) | |
tree | cd172df35bbbc323a22f426774bc859ed6080cb5 /sql/sql_lex.h | |
parent | e889b48749583751895b8f34e1906c93f69d53f0 (diff) | |
parent | 9baf84e99a6d7edd36c777593a90671d02aacbc9 (diff) | |
download | mariadb-git-294fb44d67ff1b12e11b7f771d5260ed2b1b97fb.tar.gz |
merge 5.1 => 5.5 : Bug#12329653
Diffstat (limited to 'sql/sql_lex.h')
-rw-r--r-- | sql/sql_lex.h | 28 |
1 files changed, 17 insertions, 11 deletions
diff --git a/sql/sql_lex.h b/sql/sql_lex.h index e6b5f23f17e..2b40741698e 100644 --- a/sql/sql_lex.h +++ b/sql/sql_lex.h @@ -800,16 +800,7 @@ public: joins on the right. */ List<String> *prev_join_using; - /* - Bitmap used in the ONLY_FULL_GROUP_BY_MODE to prevent mixture of aggregate - functions and non aggregated fields when GROUP BY list is absent. - Bits: - 0 - non aggregated fields are used in this select, - defined as NON_AGG_FIELD_USED. - 1 - aggregate functions are used in this select, - defined as SUM_FUNC_USED. - */ - uint8 full_group_by_flag; + void init_query(); void init_select(); st_select_lex_unit* master_unit(); @@ -918,7 +909,22 @@ public: void clear_index_hints(void) { index_hints= NULL; } -private: + /* + For MODE_ONLY_FULL_GROUP_BY we need to maintain two flags: + - Non-aggregated fields are used in this select. + - Aggregate functions are used in this select. + In MODE_ONLY_FULL_GROUP_BY only one of these may be true. + */ + bool non_agg_field_used() const { return m_non_agg_field_used; } + bool agg_func_used() const { return m_agg_func_used; } + + void set_non_agg_field_used(bool val) { m_non_agg_field_used= val; } + void set_agg_func_used(bool val) { m_agg_func_used= val; } + +private: + bool m_non_agg_field_used; + bool m_agg_func_used; + /* current index hint kind. used in filling up index_hints */ enum index_hint_type current_index_hint_type; index_clause_map current_index_hint_clause; |