You've already forked mariadb-columnstore-engine
							
							
				mirror of
				https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
				synced 2025-10-25 21:17:42 +03:00 
			
		
		
		
	MCOL-1519 The server won`t use GROUP BY handler in queries with:
unsupported JOIN types impossible HAVING impossible WHERE
This commit is contained in:
		| @@ -1139,10 +1139,74 @@ static MYSQL_SYSVAR_ULONG( | |||||||
|     0); |     0); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /*@brief  check_walk - It traverses filter conditions*/ | ||||||
|  | /************************************************************ | ||||||
|  |  * DESCRIPTION: | ||||||
|  |  * It traverses filter predicates looking for unsupported | ||||||
|  |  * JOIN types: non-equi JOIN, e.g  t1.c1 > t2.c2; | ||||||
|  |  * logical OR. | ||||||
|  |  * PARAMETERS: | ||||||
|  |  *    thd - THD pointer. | ||||||
|  |  *    derived - TABLE_LIST* to work with. | ||||||
|  |  * RETURN: | ||||||
|  |  *    derived_handler if possible | ||||||
|  |  *    NULL in other case | ||||||
|  |  ***********************************************************/ | ||||||
|  | void check_walk(const Item* item, void* arg) | ||||||
|  | { | ||||||
|  |     bool* unsupported_feature  = static_cast<bool*>(arg); | ||||||
|  |     if ( *unsupported_feature ) | ||||||
|  |         return; | ||||||
|  |     switch (item->type()) | ||||||
|  |     { | ||||||
|  |         case Item::FUNC_ITEM: | ||||||
|  |         { | ||||||
|  |             Item_func* ifp = (Item_func*)item; | ||||||
|  |  | ||||||
|  |             if ( ifp->functype() != Item_func::EQ_FUNC ) | ||||||
|  |             { | ||||||
|  |                 if ( ifp->argument_count() == 2 && | ||||||
|  |                     ifp->arguments()[0]->type() == Item::FIELD_ITEM && | ||||||
|  |                     ifp->arguments()[1]->type() == Item::FIELD_ITEM ) | ||||||
|  |                 { | ||||||
|  |                     Item_field* left= static_cast<Item_field*>(ifp->arguments()[0]); | ||||||
|  |                     Item_field* right= static_cast<Item_field*>(ifp->arguments()[1]); | ||||||
|  |  | ||||||
|  |                     if ( left->field->table != right->field->table ) | ||||||
|  |                     { | ||||||
|  |                         *unsupported_feature = true; | ||||||
|  |                         return; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         case Item::COND_ITEM: | ||||||
|  |         { | ||||||
|  |             Item_cond* icp = (Item_cond*)item; | ||||||
|  |             if ( is_cond_or(icp) ) | ||||||
|  |             { | ||||||
|  |                 *unsupported_feature = true; | ||||||
|  |             } | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  |         default: | ||||||
|  |         { | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| /*@brief  create_calpont_group_by_handler- Creates handler*/ | /*@brief  create_calpont_group_by_handler- Creates handler*/ | ||||||
| /*********************************************************** | /*********************************************************** | ||||||
|  * DESCRIPTION: |  * DESCRIPTION: | ||||||
|  * Creates a group_by pushdown handler. |  * Creates a group_by pushdown handler if there is no: | ||||||
|  |  *  non-equi JOIN, e.g * t1.c1 > t2.c2 | ||||||
|  |  *  logical OR in the filter predicates | ||||||
|  |  *  Impossible WHERE | ||||||
|  |  *  Impossible HAVING | ||||||
|  |  * Valid queries with the last two crashes the server if processed. | ||||||
|  * Details are in server/sql/group_by_handler.h |  * Details are in server/sql/group_by_handler.h | ||||||
|  * PARAMETERS: |  * PARAMETERS: | ||||||
|  *    thd - THD pointer. |  *    thd - THD pointer. | ||||||
| @@ -1155,19 +1219,42 @@ static group_by_handler* | |||||||
| create_calpont_group_by_handler(THD* thd, Query* query) | create_calpont_group_by_handler(THD* thd, Query* query) | ||||||
| { | { | ||||||
|     ha_calpont_group_by_handler* handler = NULL; |     ha_calpont_group_by_handler* handler = NULL; | ||||||
|  |     LEX* lex = thd->lex; | ||||||
|  |     SELECT_LEX *select_lex = &lex->select_lex; | ||||||
|  |  | ||||||
|     // Create a handler if there is an agregate or a GROUP BY |     // Create a handler if query is valid. See comments for details. | ||||||
|     // and if vtable was explicitly disabled. |  | ||||||
|     if ( thd->infinidb_vtable.vtable_state == THD::INFINIDB_DISABLE_VTABLE |     if ( thd->infinidb_vtable.vtable_state == THD::INFINIDB_DISABLE_VTABLE | ||||||
|             && thd->variables.infinidb_vtable_mode == 0 |         && ( thd->variables.infinidb_vtable_mode == 0 | ||||||
|             && ( query->group_by || thd->lex->select_lex.with_sum_func) ) |             || thd->variables.infinidb_vtable_mode == 2 ) | ||||||
|  |         && ( query->group_by || thd->lex->select_lex.with_sum_func ) | ||||||
|  |         && ( select_lex->having && select_lex->having_value != Item::COND_FALSE ) | ||||||
|  |         && ( select_lex->cond_value && select_lex->cond_value != Item::COND_FALSE ) ) | ||||||
|     { |     { | ||||||
|         handler = new ha_calpont_group_by_handler(thd, query); |         // Unsupported JOIN conditions check. | ||||||
|  |         bool unsupported_feature = false; | ||||||
|  |         { | ||||||
|  |             JOIN *join = select_lex->join; | ||||||
|  |             Item_cond *icp = 0; | ||||||
|  |  | ||||||
|         // Notify the server, that CS handles GROUP BY, ORDER BY and HAVING clauses. |             if (join != 0) | ||||||
|         query->group_by = NULL; |                 icp = reinterpret_cast<Item_cond*>(join->conds); | ||||||
|         query->order_by = NULL; |  | ||||||
|         query->having = NULL; |             if ( unsupported_feature == false | ||||||
|  |                 && join->table_count > 1 && icp ) | ||||||
|  |             { | ||||||
|  |                 icp->traverse_cond(check_walk, &unsupported_feature, Item::POSTFIX); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if ( !unsupported_feature ) | ||||||
|  |         { | ||||||
|  |             handler = new ha_calpont_group_by_handler(thd, query); | ||||||
|  |  | ||||||
|  |             // Notify the server, that CS handles GROUP BY, ORDER BY and HAVING clauses. | ||||||
|  |             query->group_by = NULL; | ||||||
|  |             query->order_by = NULL; | ||||||
|  |             query->having = NULL; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return handler; |     return handler; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user