MySQL 8.4.3
Source Code Documentation
|
A key part specification. More...
#include <parse_tree_nodes.h>
Public Member Functions | |
PT_key_part_specification (const POS &pos, Item *expression, enum_order order) | |
Constructor for a functional key part. More... | |
PT_key_part_specification (const POS &pos, const LEX_CSTRING &column_name, enum_order order, int prefix_length) | |
Constructor for a "normal" key part. More... | |
bool | do_contextualize (Parse_context *pc) override |
Contextualize this key part specification. More... | |
Item * | get_expression () const |
Get the indexed expression. More... | |
enum_order | get_order () const |
bool | is_explicit () const |
bool | has_expression () const |
LEX_CSTRING | get_column_name () const |
Get the column that this key part points to. More... | |
int | get_prefix_length () const |
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... | |
Private Types | |
typedef Parse_tree_node | super |
Private Attributes | |
Item * | m_expression |
The indexed expression in case this is a functional key part. More... | |
enum_order | m_order |
The direction of the index. More... | |
LEX_CSTRING | m_column_name {} |
The name of the column that this key part indexes. More... | |
int | m_prefix_length = 0 |
If this is greater than zero, it represents how many bytes of the column that is indexed. 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 Parse_tree_node_tmpl< Context > | |
POS | m_pos |
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... | |
virtual void | add_json_info (Json_object *json_obj) |
Add all the node-specific json fields. More... | |
A key part specification.
This can either be a "normal" key part (a key part that points to a column), or this can be a functional key part (a key part that points to an expression).
|
private |
PT_key_part_specification::PT_key_part_specification | ( | const POS & | pos, |
Item * | expression, | ||
enum_order | order | ||
) |
Constructor for a functional key part.
pos | Position of this clause in the SQL statement. |
expression | The expression to index. |
order | The direction of the index. |
PT_key_part_specification::PT_key_part_specification | ( | const POS & | pos, |
const LEX_CSTRING & | column_name, | ||
enum_order | order, | ||
int | prefix_length | ||
) |
Constructor for a "normal" key part.
That is a key part that points to a column and not an expression.
pos | Position of this clause in the SQL statement. |
column_name | The column name that this key part points to. |
order | The direction of the index. |
prefix_length | How many bytes or characters this key part should index, or zero if it should index the entire column. |
|
override |
Contextualize this key part specification.
This will also call itemize on the indexed expression if this is a functional key part.
pc | The parse context |
true | on error |
false | on success |
|
inline |
Get the column that this key part points to.
This is only valid if this key part isn't a functional index. The caller must thus check the return value of has_expression() before calling this function.
|
inline |
Get the indexed expression.
The caller must ensure that has_expression() returns true before calling this.
|
inline |
|
inline |
|
inline |
true | if the key part contains an expression (and thus is a functional key part). |
false | if the key part doesn't contain an expression. |
|
inline |
true | if the user explicitly specified a direction (asc/desc). |
false | if the user didn't explicitly specify a direction. |
|
private |
The name of the column that this key part indexes.
|
private |
The indexed expression in case this is a functional key part.
Only valid if has_expression() returns true.
|
private |
The direction of the index.
|
private |
If this is greater than zero, it represents how many bytes of the column that is indexed.
Note that for non-binary columns (VARCHAR, TEXT etc), this is the number of characters.