My Project
Public Member Functions
sp_instr_set Class Reference

#include <sp_instr.h>

Inheritance diagram for sp_instr_set:
sp_lex_instr sp_instr Sql_alloc sp_printable

List of all members.

Public Member Functions

 sp_instr_set (uint ip, LEX *lex, uint offset, Item *value_item, LEX_STRING value_query, bool is_lex_owner)
virtual void print (String *str)
virtual bool exec_core (THD *thd, uint *nextp)
virtual bool is_invalid () const
virtual void invalidate ()
virtual bool on_after_expr_parsing (THD *thd)
virtual LEX_STRING get_expr_query () const

Detailed Description

sp_instr_set represents SET-statememnts, which deal with SP-variables.


Member Function Documentation

bool sp_instr_set::exec_core ( THD *  thd,
uint *  nextp 
) [virtual]

Execute core function of instruction after all preparations (e.g. setting of proper LEX, saving part of the thread context).

Parameters:
thdThread context.
nextp[out]next instruction pointer
Returns:
Error flag.

Implements sp_lex_instr.

virtual LEX_STRING sp_instr_set::get_expr_query ( ) const [inline, virtual]
Returns:
the expression query string. This string can not be passed directly to the parser as it is most likely not a valid SQL-statement.
Note:
as it can be seen in the get_query() implementation, get_expr_query() might return EMPTY_STR. EMPTY_STR means that no query-expression is available. That happens when class provides different implementation of get_query(). Strictly speaking, this is a drawback of the current class hierarchy.

Reimplemented from sp_lex_instr.

virtual void sp_instr_set::invalidate ( ) [inline, virtual]

Invalidate the object.

Implements sp_lex_instr.

virtual bool sp_instr_set::is_invalid ( ) const [inline, virtual]
Return values:
falseif the object (i.e. LEX-object) is valid and exec_core() can be just called.
trueif the object is not valid any longer, exec_core() can not be called. The original query string should be re-parsed and a new LEX-object should be used.

Implements sp_lex_instr.

virtual bool sp_instr_set::on_after_expr_parsing ( THD *  thd) [inline, virtual]

Callback function which is called after the statement query string is successfully parsed, and the thread context has not been switched to the outer context. The thread context contains new LEX-object corresponding to the parsed query string.

Parameters:
thdThread context.
Returns:
Error flag.

Reimplemented from sp_lex_instr.


The documentation for this class was generated from the following files:
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines