MySQL 5.6.14 Source Code Document
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
opt_explain_json_namespace::simple_sort_ctx Class Reference
Inheritance diagram for opt_explain_json_namespace::simple_sort_ctx:
Collaboration diagram for opt_explain_json_namespace::simple_sort_ctx:

Public Member Functions

 simple_sort_ctx (Explain_context_enum type_arg, const char *name_arg, context *parent_arg, const Explain_format_flags *flags, Explain_sort_clause clause)
virtual bool add_join_tab (joinable_ctx *ctx)
virtual bool add_where_subquery (subquery_ctx *ctx, SELECT_LEX_UNIT *subquery)
virtual bool find_and_set_derived (context *subquery)
virtual size_t id (bool hide)
virtual bool cacheable ()
virtual bool dependent ()
- Public Member Functions inherited from opt_explain_json_namespace::joinable_ctx
 joinable_ctx (Explain_context_enum type_arg, const char *name_arg, context *parent_arg)
- Public Member Functions inherited from opt_explain_json_namespace::context
 context (Explain_context_enum type_arg, const char *name_arg, context *parent_arg)
virtual bool format (Opt_trace_context *json)
bool is_query_block () const
virtual class qep_rowentry ()
virtual void set_child (context *child)
virtual void set_union_result (union_result_ctx *ctx)
 associate CTX_UNION_RESULT node with CTX_UNION node
virtual bool add_subquery (subquery_list_enum subquery_type, subquery_ctx *ctx)
virtual bool format_nested_loop (Opt_trace_context *json)
virtual void set_sort (sort_ctx *ctx)
virtual bool add_query_spec (context *ctx)
virtual bool format_derived (Opt_trace_context *json)
 Helper function to format output for derived subquery if any.
virtual bool format_where (Opt_trace_context *json)
 Helper function to format output for associated WHERE subqueries if any.
virtual bool format_unit (Opt_trace_context *json)
 Helper function to format output for HAVING, ORDER/GROUP BY subqueries.
- Public Member Functions inherited from Explain_context
 Explain_context (Explain_context_enum type_arg)

Protected Member Functions

virtual bool format_body (Opt_trace_context *json, Opt_trace_object *obj)

Protected Attributes

joinable_ctxjoin_tab

Additional Inherited Members

- Static Public Member Functions inherited from Sql_alloc
static void * operator new (size_t size) throw ()
static void * operator new[] (size_t size) throw ()
static void * operator new[] (size_t size, MEM_ROOT *mem_root) throw ()
static void * operator new (size_t size, MEM_ROOT *mem_root) throw ()
static void operator delete (void *ptr, size_t size)
static void operator delete (void *ptr, MEM_ROOT *mem_root)
static void operator delete[] (void *ptr, MEM_ROOT *mem_root)
static void operator delete[] (void *ptr, size_t size)
- Public Attributes inherited from opt_explain_json_namespace::context
contextparent
 link to parent node or NULL

Detailed Description

Base class for CTX_ORDER_BY, CTX_GROUP_BY and node class for CTX_DISTINCT

This class represents context for simple ORDER BY/GROUP BY/DISTINCT clauses (the clause is effective for the single JOIN_TAB).

Definition at line 923 of file opt_explain_json.cc.

Member Function Documentation

virtual bool opt_explain_json_namespace::simple_sort_ctx::add_join_tab ( joinable_ctx ctx)
inlinevirtual

Add a CTX_JOIN_TAB node to a CTX_JOIN node

Parameters
ctxCTX_JOIN_TAB node
Return values
falseOk
trueError

Reimplemented from opt_explain_json_namespace::context.

Definition at line 944 of file opt_explain_json.cc.

virtual bool opt_explain_json_namespace::simple_sort_ctx::add_where_subquery ( subquery_ctx ctx,
SELECT_LEX_UNIT *  subquery 
)
inlinevirtual

Associate WHERE subqueries of given context and unit with this object

Parameters
ctxContext of WHERE subquery
subqueryFor CTX_JOIN_TAB: match given unit with a previously collected by the register_where_subquery function.

Reimplemented from opt_explain_json_namespace::context.

Definition at line 950 of file opt_explain_json.cc.

Here is the call graph for this function:

virtual bool opt_explain_json_namespace::simple_sort_ctx::find_and_set_derived ( context subquery)
inlinevirtual

Try to associate a derived subquery node with this or underlying node

Parameters
subqueryDerived subquery node
Return values
trueSuccess
falseCan't associate: this node or its child nodes are not derived from the subquery

Reimplemented from opt_explain_json_namespace::context.

Definition at line 956 of file opt_explain_json.cc.

Here is the call graph for this function:

virtual bool opt_explain_json_namespace::simple_sort_ctx::format_body ( Opt_trace_context json,
Opt_trace_object obj 
)
inlineprotectedvirtual

Format JSON object body

Parameters
jsonFormatter
objObject of this body
Return values
falseOk
trueError

Implements opt_explain_json_namespace::context.

Definition at line 966 of file opt_explain_json.cc.

Here is the call graph for this function:

virtual size_t opt_explain_json_namespace::simple_sort_ctx::id ( bool  hide)
inlinevirtual

Analogue of the "id" column in the traditional EXPLAIN output

Parameters
hideif true, ban the output of K_SELECT_ID JSON property in the underlying table_with_where_and_derived_ctx objects
Returns
"Select number" that is associated with this node

Implements opt_explain_json_namespace::context.

Definition at line 961 of file opt_explain_json.cc.

Here is the call graph for this function:


The documentation for this class was generated from the following file: