1#ifndef PARTITION_INFO_INCLUDED
2#define PARTITION_INFO_INCLUDED
48#define NOT_A_PARTITION_ID UINT_MAX32
166 uchar *min_val,
uchar *max_val, uint min_len, uint max_len, uint
flags,
495 bool check_partition_function);
514 bool copy_default_values,
MY_BITMAP *used_partitions);
529 bool *prune_needs_default_values,
567 const char *part_name);
Kerberos Client Authentication nullptr
Definition: auth_kerberos_client_plugin.cc:251
Definition: sql_bitmap.h:154
This class encapsulates a data change operation.
Definition: sql_data_change.h:74
Create_field is a description a field/column that may or may not exists in a table.
Definition: create_field.h:51
Base class that is used to represent any kind of expression in a relational query.
Definition: item.h:930
Definition: sql_list.h:494
Definition: partition_info.h:180
partition_element *const current_partition
Definition: partition_info.h:183
uint curr_list_object
Definition: partition_info.h:186
part_elem_value * curr_list_val
Definition: partition_info.h:185
partition_info *const part_info
Definition: partition_info.h:182
bool add_column_list_value(THD *thd, Item *item)
Add a column value in VALUES LESS THAN or VALUES IN.
Definition: partition_info.cc:2064
bool init_column_part()
Initialize a new column for VALUES {LESS THAN|IN}.
Definition: partition_info.cc:2117
bool reorganize_into_single_field_col_val()
Reorganize the preallocated buffer into a single field col list.
Definition: partition_info.cc:2166
part_column_list_val * add_column_value()
Create a new column value in current list.
Definition: partition_info.cc:1985
Parser_partition_info(partition_info *const part_info, partition_element *const current_partition, partition_element *const curr_part_elem, part_elem_value *curr_list_val, uint curr_list_object)
Definition: partition_info.h:190
void init_col_val(part_column_list_val *col_val, Item *item)
Initialise part_elem_value object at setting of a new object.
Definition: partition_info.cc:2030
partition_element *const curr_part_elem
Definition: partition_info.h:184
uint count_curr_subparts
Definition: partition_info.h:187
bool add_max_value()
Create a new column value in current list with maxvalue.
Definition: partition_info.cc:1963
Class for partitioning specific operations.
Definition: partition_handler.h:194
Using this class is fraught with peril, and you need to be very careful when doing so.
Definition: sql_string.h:167
For each client connection we create a separate thread with THD serving as a thread/connection descri...
Definition: sql_lexer_thd.h:36
The handler class is the interface for dynamically loadable storage engines.
Definition: handler.h:4583
std::unordered_set, but with my_malloc, so that you can track the memory used using PSI memory keys.
Definition: map_helpers.h:177
A (partial) implementation of std::deque allocating its blocks on a MEM_ROOT.
Definition: mem_root_deque.h:111
Definition: partition_element.h:108
Definition: partition_info.h:209
bool init_partition_bitmap(MY_BITMAP *bitmap, MEM_ROOT *mem_root)
Allocate memory for one partitions bitmap and initialize it.
Definition: partition_info.cc:2862
char * part_func_string
Partition expression as string.
Definition: partition_info.h:349
uint num_full_part_fields
Definition: partition_info.h:377
longlong err_value
Definition: partition_info.h:347
bool use_default_num_subpartitions
Definition: partition_info.h:394
uchar ** part_field_buffers
Definition: partition_info.h:285
uint num_parts
Definition: partition_info.h:370
bool set_used_partition(THD *thd, const mem_root_deque< Item * > &fields, const mem_root_deque< Item * > &values, COPY_INFO &info, bool copy_default_values, MY_BITMAP *used_partitions)
Mark the partition, the record belongs to, as used.
Definition: partition_info.cc:471
bool fix_partition_values(part_elem_value *val, partition_element *part_elem, uint part_id)
This function handles the case of function-based partitioning.
Definition: partition_info.cc:2211
LIST_PART_ENTRY * list_array
Definition: partition_info.h:324
Key_map all_fields_in_PF
Definition: partition_info.h:360
Field ** part_charset_field_array
Definition: partition_info.h:265
uint get_next_used_partition(uint part_id) const
Definition: partition_info.h:544
get_partitions_in_range_iter get_subpart_iter_for_interval
Definition: partition_info.h:341
bool is_partition_used(uint part_id) const
Definition: partition_info.h:532
size_t part_func_len
Definition: partition_info.h:367
get_part_id_func get_part_partition_id
Definition: partition_info.h:242
bool fix_parser_data(THD *thd)
Fix partition data from parser.
Definition: partition_info.cc:2397
bool check_partition_info(THD *thd, handlerton **eng_type, handler *file, HA_CREATE_INFO *info, bool check_partition_function)
Definition: partition_info.cc:1414
bool has_null_value
Definition: partition_info.h:402
MY_BITMAP full_part_field_set
Definition: partition_info.h:278
bool use_default_num_partitions
Definition: partition_info.h:391
get_part_id_func get_part_partition_id_charset
Definition: partition_info.h:259
Item * get_column_item(Item *item, Field *field)
Get column item with a proper character set according to the field.
Definition: partition_info.cc:2275
partition_type subpart_type
Definition: partition_info.h:365
bool is_pruning_completed
True if pruning has been completed and can not be pruned any further, even if there are subqueries or...
Definition: partition_info.h:412
Key_map some_fields_in_PF
Definition: partition_info.h:361
char * create_default_partition_names(uint num_parts, uint start_no)
Definition: partition_info.cc:546
uint num_partitions_used()
Definition: partition_info.h:538
bool use_default_partitions
Definition: partition_info.h:390
void report_part_expr_error(bool use_subpart_expr)
Check what kind of error to report.
Definition: partition_info.cc:1870
uint has_null_part_id
Definition: partition_info.h:379
partition_type part_type
Definition: partition_info.h:364
uint num_subparts
Definition: partition_info.h:371
Field ** subpart_charset_field_array
Definition: partition_info.h:266
List< char > part_field_list
Definition: partition_info.h:217
longlong * range_int_array
Definition: partition_info.h:323
List< partition_element > temp_partitions
Definition: partition_info.h:215
bool can_prune_insert(THD *thd, enum_duplicates duplic, COPY_INFO &update, const mem_root_deque< Item * > &update_fields, const mem_root_deque< Item * > &fields, bool empty_values, enum_can_prune *can_prune_partitions, bool *prune_needs_default_values, MY_BITMAP *used_partitions)
Checks if possible to do prune partitions on insert.
Definition: partition_info.cc:312
char * find_duplicate_field()
Definition: partition_info.cc:812
Field ** part_field_array
Definition: partition_info.h:263
bool set_up_defaults_for_partitioning(Partition_handler *part_handler, HA_CREATE_INFO *info, uint start_no)
Definition: partition_info.cc:783
bool is_full_part_expr_in_fields(const mem_root_deque< Item * > &fields)
Check if all partitioning fields are included.
Definition: partition_info.cc:1927
part_column_list_val * list_col_array
Definition: partition_info.h:326
uint num_subpart_fields
Definition: partition_info.h:376
bool bitmaps_are_initialized
Definition: partition_info.h:319
bool set_part_expr(char *start_token, Item *item_ptr, char *end_token, bool is_subpart)
Definition: partition_info.cc:1668
Item * subpart_expr
Definition: partition_info.h:291
uint num_list_values
Definition: partition_info.h:373
uchar ** restore_part_field_ptrs
Definition: partition_info.h:287
Key_map all_fields_in_PPF
Definition: partition_info.h:360
Field ** subpart_field_array
Definition: partition_info.h:264
bool set_partition_bitmaps(Table_ref *table_list)
Set read/lock_partitions bitmap over non pruned partitions.
Definition: partition_info.cc:263
Key_map all_fields_in_SPF
Definition: partition_info.h:360
uint get_first_used_partition() const
Definition: partition_info.h:541
MY_BITMAP lock_partitions
Definition: partition_info.h:318
bool add_named_partition(const char *part_name, size_t length)
Mark named [sub]partition to be used/locked.
Definition: partition_info.cc:169
bool set_up_default_partitions(Partition_handler *part_handler, HA_CREATE_INFO *info, uint start_no)
Definition: partition_info.cc:644
char * subpart_func_string
Subpartition expression as string.
Definition: partition_info.h:350
uchar ** subpart_field_buffers
Definition: partition_info.h:286
bool check_list_constants(THD *thd)
Definition: partition_info.cc:1247
bool fix_column_value_functions(THD *thd, part_elem_value *val, uint part_id)
Evaluate VALUES functions for column list values.
Definition: partition_info.cc:2300
bool set_read_partitions(List< String > *partition_names)
Prune away partitions not mentioned in the PARTITION () clause, if used.
Definition: partition_info.cc:222
uint get_tot_partitions() const
Definition: partition_info.h:482
bool list_of_subpart_fields
Definition: partition_info.h:398
bool is_sub_partitioned() const
Definition: partition_info.h:477
get_subpart_id_func get_subpartition_id_charset
Definition: partition_info.h:260
enum_can_prune
PRUNE_NO - Unable to prune.
Definition: partition_info.h:524
@ PRUNE_DEFAULTS
Definition: partition_info.h:524
@ PRUNE_NO
Definition: partition_info.h:524
@ PRUNE_YES
Definition: partition_info.h:524
partition_info()
Definition: partition_info.h:414
List< char > subpart_field_list
Definition: partition_info.h:218
bool default_partitions_setup
Definition: partition_info.h:395
void print_debug(const char *str, uint *)
Definition: partition_info.cc:2729
bool set_up_default_subpartitions(Partition_handler *part_handler, HA_CREATE_INFO *info)
Definition: partition_info.cc:721
bool check_range_constants(THD *thd)
Definition: partition_info.cc:1097
void print_no_partition_found(THD *thd, TABLE *table)
Definition: partition_info.cc:1628
char * create_default_subpartition_name(uint subpart_no, const char *part_name)
Definition: partition_info.cc:606
uint num_columns
Definition: partition_info.h:352
get_subpart_id_func get_subpartition_id
Definition: partition_info.h:251
bool check_partition_field_length()
Definition: partition_info.cc:1707
bool linear_hash_ind
Definition: partition_info.h:399
bool is_auto_partitioned
Definition: partition_info.h:401
bool fixed
Definition: partition_info.h:400
void set_show_version_string(String *packet)
Definition: partition_info.cc:574
bool list_of_part_fields
Definition: partition_info.h:397
uint num_part_fields
Definition: partition_info.h:375
MY_BITMAP read_partitions
Definition: partition_info.h:317
bool use_default_subpartitions
Definition: partition_info.h:393
Item * item_list
Definition: partition_info.h:293
uchar ** restore_subpart_field_ptrs
Definition: partition_info.h:288
get_part_id_func get_partition_id
Definition: partition_info.h:232
handlerton * default_engine_type
Definition: partition_info.h:363
part_column_list_val * range_col_array
Definition: partition_info.h:325
bool defined_max_value
Definition: partition_info.h:396
bool is_fields_in_part_expr(const mem_root_deque< Item * > &fields)
Check if fields are in the partitioning expression.
Definition: partition_info.cc:1911
bool is_partition_locked(uint part_id) const
Definition: partition_info.h:535
bool check_engine_mix(handlerton *engine_type, bool default_engine)
Definition: partition_info.cc:1017
partition_info * get_clone(THD *thd, bool reset=false)
Definition: partition_info.cc:78
List< partition_element > partitions
Definition: partition_info.h:214
bool set_named_partition_bitmap(const char *part_name, size_t length)
Mark named [sub]partition to be used/locked.
Definition: partition_info.cc:205
uint16 linear_hash_mask
Definition: partition_info.h:385
Field ** full_part_field_array
Definition: partition_info.h:271
size_t subpart_func_len
Definition: partition_info.h:368
static bool compare_column_values(const part_column_list_val *a, const part_column_list_val *b)
Definition: partition_info.cc:1220
bool same_key_column_order(List< Create_field > *create_list)
Check if the partitioning columns are in the same order as the given list.
Definition: partition_info.cc:2718
const char * find_duplicate_name()
Definition: partition_info.cc:898
Item * part_expr
Definition: partition_info.h:290
TABLE * table
Definition: partition_info.h:354
partition_element * get_part_elem(const char *partition_name, uint32 *part_id)
Get part_elem and part_id from partition name.
Definition: partition_info.cc:848
partition_info * get_full_clone(THD *thd)
Definition: partition_info.cc:147
bool column_list
Definition: partition_info.h:403
bool has_same_partitioning(partition_info *new_part_info)
Check if the new part_info has the same partitioning.
Definition: partition_info.cc:2503
get_partitions_in_range_iter get_part_iter_for_interval
Definition: partition_info.h:336
enum_key_algorithm key_algorithm
Definition: partition_info.h:387
bool set_up_charset_field_preps()
Definition: partition_info.cc:1738
static MEM_ROOT mem_root
Definition: client_plugin.cc:114
static int flags[50]
Definition: hp_test1.cc:40
static bool bitmap_is_set(const MY_BITMAP *map, uint bit)
Definition: my_bitmap.h:95
uint bitmap_bits_set(const MY_BITMAP *map)
Definition: my_bitmap.cc:416
uint bitmap_get_next_set(const MY_BITMAP *map, uint bitmap_bit)
Get the next set bit.
Definition: my_bitmap.cc:462
uint bitmap_get_first_set(const MY_BITMAP *map)
Definition: my_bitmap.cc:439
Some integer typedefs for easier portability.
unsigned long long int ulonglong
Definition: my_inttypes.h:56
unsigned char uchar
Definition: my_inttypes.h:52
long long int longlong
Definition: my_inttypes.h:55
uint16_t uint16
Definition: my_inttypes.h:65
uint32_t uint32
Definition: my_inttypes.h:67
static uint update
Definition: myisamlog.cc:94
static char * default_engine
Definition: mysqlslap.cc:152
std::string HARNESS_EXPORT reset()
get 'reset attributes' ESC sequence.
Definition: vt100.cc:37
std::string str(const mysqlrouter::ConfigGenerator::Options::Endpoint &ep)
Definition: config_generator.cc:1105
bool length(const dd::Spatial_reference_system *srs, const Geometry *g1, double *length, bool *null) noexcept
Computes the length of linestrings and multilinestrings.
Definition: length.cc:76
partition_type
An enum and a struct to handle partitioning and subpartitioning.
Definition: partition_element.h:33
bool validate_partition_tablespace_name_lengths(partition_info *part_info)
Check if all tablespace names specified for partitions have a valid length.
Definition: partition_info.cc:2795
enum_key_algorithm
PARTITION BY KEY ALGORITHM=N Which algorithm to use for hashing the fields.
Definition: partition_info.h:174
static void init_single_partition_iterator(uint32 part_id, PARTITION_ITERATOR *part_iter)
Definition: partition_info.h:578
bool check_partition_dirs(partition_info *part_info)
Definition: partition_info.cc:1826
uint32 get_next_partition_id_range(PARTITION_ITERATOR *part_iter)
Definition: sql_partition.cc:6037
bool validate_partition_tablespace_names(partition_info *part_info, const handlerton *default_engine)
Check if all tablespace names specified for partitions are valid.
Definition: partition_info.cc:2822
int(* get_subpart_id_func)(partition_info *part_info, uint32 *part_id)
Definition: partition_info.h:125
int(* get_part_id_func)(partition_info *part_info, uint32 *part_id, longlong *func_value)
Definition: partition_info.h:123
int(* get_partitions_in_range_iter)(partition_info *part_info, bool is_subpart, uint32 *store_length_array, uchar *min_val, uchar *max_val, uint min_len, uint max_len, uint flags, PARTITION_ITERATOR *part_iter)
Get an iterator for set of partitions that match given field-space interval.
Definition: partition_info.h:164
uint32(* partition_iter_func)(PARTITION_ITERATOR *part_iter)
A "Get next" function for partition iterator.
Definition: partition_info.h:74
bool fill_partition_tablespace_names(partition_info *part_info, Tablespace_hash_set *tablespace_set)
Fill the Tablespace_hash_set with the tablespace names used by the partitions on the table.
Definition: partition_info.cc:2767
static void init_all_partitions_iterator(partition_info *part_info, PARTITION_ITERATOR *part_iter)
Definition: partition_info.h:587
bool has_external_data_or_index_dir(partition_info &pi)
Predicate which returns true if any partition or subpartition uses an external data directory or exte...
Definition: partition_info.cc:2738
Contains classes representing SQL-data change statements.
enum_duplicates
Definition: sql_data_change.h:48
Struct to hold information about the table that should be created.
Definition: handler.h:3210
Definition: partition_info.h:117
uint32 partition_id
Definition: partition_info.h:119
longlong list_value
Definition: partition_info.h:118
The MEM_ROOT is a simple arena, where allocations are carved out of larger blocks.
Definition: my_alloc.h:83
Definition: my_bitmap.h:43
Definition: partition_info.h:104
ulonglong end
Definition: partition_info.h:107
ulonglong cur
Definition: partition_info.h:106
ulonglong start
Definition: partition_info.h:105
Definition: partition_info.h:98
uint32 end
Definition: partition_info.h:101
uint32 start
Definition: partition_info.h:99
uint32 cur
Definition: partition_info.h:100
Partition set iterator.
Definition: partition_info.h:91
bool ret_null_part
Definition: partition_info.h:97
struct st_field_value_range field_vals
Definition: partition_info.h:112
bool ret_null_part_orig
Definition: partition_info.h:97
partition_info * part_info
Definition: partition_info.h:114
struct st_part_num_range part_nums
Definition: partition_info.h:111
partition_iter_func get_next
Definition: partition_info.h:92
handlerton is a singleton structure - one instance per storage engine - to provide access to storage ...
Definition: handler.h:2740
Definition: partition_element.h:65
Definition: partition_element.h:100