mirror of
https://github.com/MariaDB/server.git
synced 2025-01-16 03:52:35 +01:00
fixed WHERE condition optimisation in PS
sql/sql_prepare.cc: reset current_select before query rexecution assirn prepared statement arena in time of execution
This commit is contained in:
parent
ba4bd06f75
commit
c92670d80b
1 changed files with 3 additions and 0 deletions
|
@ -1584,6 +1584,7 @@ void reset_stmt_for_execute(THD *thd, LEX *lex)
|
|||
unit->reinit_exec_mechanism();
|
||||
}
|
||||
}
|
||||
lex->current_select= &lex->select_lex;
|
||||
}
|
||||
|
||||
|
||||
|
@ -1666,10 +1667,12 @@ void mysql_stmt_execute(THD *thd, char *packet, uint packet_length)
|
|||
mysql_delete(), mysql_update() and mysql_select() to not to
|
||||
have re-check on setup_* and other things ..
|
||||
*/
|
||||
thd->current_arena= stmt;
|
||||
thd->protocol= &thd->protocol_prep; // Switch to binary protocol
|
||||
mysql_execute_command(thd);
|
||||
thd->lex->unit.cleanup();
|
||||
thd->protocol= &thd->protocol_simple; // Use normal protocol
|
||||
thd->current_arena= 0;
|
||||
|
||||
if (!(specialflag & SPECIAL_NO_PRIOR))
|
||||
my_pthread_setprio(pthread_self(), WAIT_PRIOR);
|
||||
|
|
Loading…
Reference in a new issue