MySQL 8.3.0
Source Code Documentation
PT_derived_table Class Reference

#include <parse_tree_nodes.h>

Inheritance diagram for PT_derived_table:
[legend]

Public Member Functions

 PT_derived_table (const POS &pos, bool lateral, PT_subquery *subquery, const LEX_CSTRING &table_alias, Create_col_name_list *column_names)
 
bool do_contextualize (Parse_context *pc) override
 
- Public Member Functions inherited from PT_table_reference
 PT_table_reference (const POS &pos)
 
virtual PT_joined_tableadd_cross_join (PT_cross_join *cj)
 Lets us build a parse tree top-down, which is necessary due to the context-dependent nature of the join syntax. More...
 
- Public Member Functions inherited from Parse_tree_node_tmpl< Context >
virtual ~Parse_tree_node_tmpl ()=default
 
bool is_contextualized () const
 
virtual bool contextualize (Context *pc) final
 
void error (Context *pc, const POS &pos) const
 syntax_error() function replacement for deferred reporting of syntax errors More...
 
void error (Context *pc, const POS &pos, const char *msg) const
 syntax_error() function replacement for deferred reporting of syntax errors More...
 
void errorf (Context *pc, const POS &pos, const char *format,...) const
 syntax_error() function replacement for deferred reporting of syntax errors More...
 

Protected Member Functions

void add_json_info (Json_object *obj) override
 Add all the node-specific json fields. More...
 
- Protected Member Functions inherited from Parse_tree_node_tmpl< Context >
 Parse_tree_node_tmpl ()=delete
 
 Parse_tree_node_tmpl (const POS &pos)
 
 Parse_tree_node_tmpl (const POS &start_pos, const POS &end_pos)
 
bool begin_parse_tree (Show_parse_tree *tree)
 
bool end_parse_tree (Show_parse_tree *tree)
 
virtual bool do_contextualize (Context *pc)
 Do all context-sensitive things and mark the node as contextualized. More...
 

Private Types

typedef PT_table_reference super
 

Private Attributes

bool m_lateral
 
PT_subquerym_subquery
 
const char *const m_table_alias
 
const Create_col_name_list column_names
 List of explicitly specified column names; if empty, no list. More...
 

Additional Inherited Members

- Public Types inherited from Parse_tree_node_tmpl< Context >
typedef Context context_t
 
- Static Public Member Functions inherited from Parse_tree_node_tmpl< Context >
static void * operator new (size_t size, MEM_ROOT *mem_root, const std::nothrow_t &arg=std::nothrow) noexcept
 
static void operator delete (void *ptr, size_t size)
 
static void operator delete (void *, MEM_ROOT *, const std::nothrow_t &) noexcept
 
- Public Attributes inherited from PT_table_reference
Table_refm_table_ref {nullptr}
 
- Public Attributes inherited from Parse_tree_node_tmpl< Context >
POS m_pos
 

Member Typedef Documentation

◆ super

Constructor & Destructor Documentation

◆ PT_derived_table()

PT_derived_table::PT_derived_table ( const POS pos,
bool  lateral,
PT_subquery subquery,
const LEX_CSTRING table_alias,
Create_col_name_list column_names 
)

Member Function Documentation

◆ add_json_info()

void PT_derived_table::add_json_info ( Json_object json_obj)
overrideprotectedvirtual

Add all the node-specific json fields.

Any class that needs to add such info should override this function rather than doing it in do_contextualize(). E.g. the parse tree node for AVG() may have "distinct" field to indicate if AVG(DISTINCT ...) is used or not.

Parameters
json_objJson object for this parse tree node.

Reimplemented from Parse_tree_node_tmpl< Context >.

◆ do_contextualize()

bool PT_derived_table::do_contextualize ( Parse_context pc)
override

Member Data Documentation

◆ column_names

const Create_col_name_list PT_derived_table::column_names
private

List of explicitly specified column names; if empty, no list.

◆ m_lateral

bool PT_derived_table::m_lateral
private

◆ m_subquery

PT_subquery* PT_derived_table::m_subquery
private

◆ m_table_alias

const char* const PT_derived_table::m_table_alias
private

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