MySQL 9.6.0
Source Code Documentation
dict0mem.h
Go to the documentation of this file.
1/*****************************************************************************
2
3Copyright (c) 1996, 2025, Oracle and/or its affiliates.
4Copyright (c) 2012, Facebook Inc.
5
6This program is free software; you can redistribute it and/or modify it under
7the terms of the GNU General Public License, version 2.0, as published by the
8Free Software Foundation.
9
10This program is designed to work with certain software (including
11but not limited to OpenSSL) that is licensed under separate terms,
12as designated in a particular file or component or in included license
13documentation. The authors of MySQL hereby grant you an additional
14permission to link the program and your derivative works with the
15separately licensed software that they have either included with
16the program or referenced in the documentation.
17
18This program is distributed in the hope that it will be useful, but WITHOUT
19ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
20FOR A PARTICULAR PURPOSE. See the GNU General Public License, version 2.0,
21for more details.
22
23You should have received a copy of the GNU General Public License along with
24this program; if not, write to the Free Software Foundation, Inc.,
2551 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
26
27*****************************************************************************/
28
29/** @file include/dict0mem.h
30 Data dictionary memory object creation
31
32 Created 1/8/1996 Heikki Tuuri
33 *******************************************************/
34
35#ifndef dict0mem_h
36#define dict0mem_h
37
38#include "sql/dd/object_id.h"
39#include "sql/dd/types/column.h"
40#include "univ.i"
41#if defined UNIV_COMPILE_TEST_FUNCS || defined UNIV_HOTBACKUP
43#endif /* UNIV_COMPILE_TEST_FUNCS || UNIV_HOTBACKUP */
44#include "btr0types.h"
45#include "data0type.h"
46#include "dict0types.h"
47#include "mem0mem.h"
48#include "rem0types.h"
49#include "row0types.h"
50#ifndef UNIV_HOTBACKUP
51#include "lock0types.h"
52#include "que0types.h"
53#endif /* !UNIV_HOTBACKUP */
54#include "hash0hash.h"
55#include "sync0rw.h"
56#include "trx0types.h"
57#include "ut0byte.h"
58#include "ut0mem.h"
59#include "ut0rnd.h"
60#ifndef UNIV_HOTBACKUP
61#include "fts0fts.h"
62#endif /* !UNIV_HOTBACKUP */
63#include "buf0buf.h"
64#include "gis0type.h"
65#ifndef UNIV_HOTBACKUP
66#include "os0once.h"
67#endif /* !UNIV_HOTBACKUP */
68#include "dict/mem.h"
69#include "ut0new.h"
70
71#include "sql/sql_const.h" /* MAX_KEY_LENGTH */
72#include "sql/table.h"
73
74#include <algorithm>
75#include <atomic>
76#include <iterator>
77#include <memory> /* std::unique_ptr */
78#include <set>
79#include <string>
80#include <vector>
81
82/* Forward declaration. */
83struct ib_rbt_t;
84
85/** Format of INSTANTLY DROPPED column names. */
86constexpr char INSTANT_DROP_SUFFIX_8_0_29[] = "_dropped_v";
87constexpr char INSTANT_DROP_PREFIX_8_0_32[] = "!hidden!_dropped_";
88
89/** index/table name used while applying REDO logs during recovery */
90constexpr char RECOVERY_INDEX_TABLE_NAME[] = "LOG_DUMMY";
91
92/** Type flags of an index: OR'ing of the flags is allowed to define a
93combination of types */
94/** @{ */
95/** clustered index; for other than auto-generated clustered indexes, also
96 DICT_UNIQUE will be set */
97constexpr uint32_t DICT_CLUSTERED = 1;
98/** unique index */
99constexpr uint32_t DICT_UNIQUE = 2;
100/** insert buffer tree */
101constexpr uint32_t DICT_IBUF = 8;
102/** bit to store the corrupted flag in SYS_INDEXES.TYPE */
103constexpr uint32_t DICT_CORRUPT = 16;
104/** FTS index; can't be combined with the other flags */
105constexpr uint32_t DICT_FTS = 32;
106/** SPATIAL index; can't be combined with the other flags */
107constexpr uint32_t DICT_SPATIAL = 64;
108/** Index on Virtual column */
109constexpr uint32_t DICT_VIRTUAL = 128;
110/* Tablespace dictionary Index. Set only in in-memory index structure. */
111constexpr uint32_t DICT_SDI = 256;
112/** Multi-value index */
113constexpr uint32_t DICT_MULTI_VALUE = 512;
114
115/** number of bits used for SYS_INDEXES.TYPE */
116constexpr uint32_t DICT_IT_BITS = 10;
117/** @} */
118
119#if 0 /* not implemented, retained for history */
120/** Types for a table object */
121#define DICT_TABLE_ORDINARY 1 /*!< ordinary table */
122#define DICT_TABLE_CLUSTER_MEMBER 2
123#define DICT_TABLE_CLUSTER \
124 3 /* this means that the table is \
125really a cluster definition */
126#endif
127
128/* Table and tablespace flags are generally not used for the Antelope file
129format except for the low order bit, which is used differently depending on
130where the flags are stored.
131
132==================== Low order flags bit =========================
133 | REDUNDANT | COMPACT | COMPRESSED and DYNAMIC
134SYS_TABLES.TYPE | 1 | 1 | 1
135dict_table_t::flags | 0 | 1 | 1
136FSP_SPACE_FLAGS | 0 | 0 | 1
137fil_space_t::flags | 0 | 0 | 1
138
139Before the 5.1 plugin, SYS_TABLES.TYPE was always DICT_TABLE_ORDINARY (1)
140and the tablespace flags field was always 0. In the 5.1 plugin, these fields
141were repurposed to identify compressed and dynamic row formats.
142
143The following types and constants describe the flags found in dict_table_t
144and SYS_TABLES.TYPE. Similar flags found in fil_space_t and FSP_SPACE_FLAGS
145are described in fsp0fsp.h. */
146
147/** @{ */
148/** dict_table_t::flags bit 0 is equal to 0 if the row format = Redundant */
149/** Redundant row format. */
150constexpr uint32_t DICT_TF_REDUNDANT = 0;
151/** dict_table_t::flags bit 0 is equal to 1 if the row format = Compact */
152/** Compact row format. */
153constexpr uint32_t DICT_TF_COMPACT = 1;
154
155/** This bitmask is used in SYS_TABLES.N_COLS to set and test whether
156the Compact page format is used, i.e ROW_FORMAT != REDUNDANT */
157constexpr uint32_t DICT_N_COLS_COMPACT = 0x80000000UL;
158
159/** Width of the COMPACT flag */
160constexpr uint32_t DICT_TF_WIDTH_COMPACT = 1;
161
162/** Width of the ZIP_SSIZE flag */
163constexpr uint32_t DICT_TF_WIDTH_ZIP_SSIZE = 4;
164
165/** Width of the ATOMIC_BLOBS flag. The ROW_FORMAT=REDUNDANT and
166ROW_FORMAT=COMPACT broke up BLOB and TEXT fields, storing the first 768 bytes
167in the clustered index. ROW_FORMAT=DYNAMIC and ROW_FORMAT=COMPRESSED
168store the whole blob or text field off-page atomically.
169Secondary indexes are created from this external data using row_ext_t
170to cache the BLOB prefixes. */
171constexpr uint32_t DICT_TF_WIDTH_ATOMIC_BLOBS = 1;
172
173/** If a table is created with the MYSQL option DATA DIRECTORY and
174innodb-file-per-table, an older engine will not be able to find that table.
175This flag prevents older engines from attempting to open the table and
176allows InnoDB to update_create_info() accordingly. */
177constexpr uint32_t DICT_TF_WIDTH_DATA_DIR = 1;
178
179/** Width of the SHARED tablespace flag.
180It is used to identify tables that exist inside a shared general tablespace.
181If a table is created with the TABLESPACE=tsname option, an older engine will
182not be able to find that table. This flag prevents older engines from attempting
183to open the table and allows InnoDB to quickly find the tablespace. */
184
185constexpr uint32_t DICT_TF_WIDTH_SHARED_SPACE = 1;
186
187/** Width of all the currently known table flags */
188constexpr uint32_t DICT_TF_BITS =
192
193/** A mask of all the known/used bits in table flags */
194constexpr uint32_t DICT_TF_BIT_MASK = ~(~0U << DICT_TF_BITS);
195
196/** Zero relative shift position of the COMPACT field */
197constexpr uint32_t DICT_TF_POS_COMPACT = 0;
198/** Zero relative shift position of the ZIP_SSIZE field */
199constexpr uint32_t DICT_TF_POS_ZIP_SSIZE =
201/** Zero relative shift position of the ATOMIC_BLOBS field */
202constexpr uint32_t DICT_TF_POS_ATOMIC_BLOBS =
204/** Zero relative shift position of the DATA_DIR field */
205constexpr uint32_t DICT_TF_POS_DATA_DIR =
207/** Zero relative shift position of the SHARED TABLESPACE field */
208constexpr uint32_t DICT_TF_POS_SHARED_SPACE =
210/** Zero relative shift position of the start of the UNUSED bits */
211constexpr uint32_t DICT_TF_POS_UNUSED =
213
214/** Bit mask of the COMPACT field */
215constexpr uint32_t DICT_TF_MASK_COMPACT = (~(~0U << DICT_TF_WIDTH_COMPACT))
217/** Bit mask of the ZIP_SSIZE field */
220/** Bit mask of the ATOMIC_BLOBS field */
221constexpr uint32_t DICT_TF_MASK_ATOMIC_BLOBS =
223/** Bit mask of the DATA_DIR field */
224constexpr uint32_t DICT_TF_MASK_DATA_DIR = (~(~0U << DICT_TF_WIDTH_DATA_DIR))
226/** Bit mask of the SHARED_SPACE field */
227constexpr uint32_t DICT_TF_MASK_SHARED_SPACE =
229
230/** Return the value of the COMPACT field */
231inline uint32_t DICT_TF_GET_COMPACT(uint32_t flags) {
233}
234/** Return the value of the ZIP_SSIZE field */
235inline uint32_t DICT_TF_GET_ZIP_SSIZE(uint32_t flags) {
237}
238/** Return the value of the ATOMIC_BLOBS field */
239inline uint32_t DICT_TF_HAS_ATOMIC_BLOBS(uint32_t flags) {
241}
242/** Return the value of the DATA_DIR field */
243inline uint32_t DICT_TF_HAS_DATA_DIR(uint32_t flags) {
245}
246/** Return the value of the SHARED_SPACE field */
247inline uint32_t DICT_TF_HAS_SHARED_SPACE(uint32_t flags) {
249}
250/** Return the contents of the UNUSED bits */
251inline uint32_t DICT_TF_GET_UNUSED(uint32_t flags) {
252 return flags >> DICT_TF_POS_UNUSED;
253}
254/** @} */
255
256/** @brief Table Flags set number 2.
257
258These flags will be stored in SYS_TABLES.MIX_LEN. All unused flags
259will be written as 0. The column may contain garbage for tables
260created with old versions of InnoDB that only implemented
261ROW_FORMAT=REDUNDANT. InnoDB engines do not check these flags
262for unknown bits in order to protect backward incompatibility. */
263/** @{ */
264/** Total number of bits in table->flags2. */
265constexpr uint32_t DICT_TF2_BITS = 11;
266constexpr uint32_t DICT_TF2_UNUSED_BIT_MASK = ~0U << DICT_TF2_BITS;
267constexpr uint32_t DICT_TF2_BIT_MASK = ~DICT_TF2_UNUSED_BIT_MASK;
268
269/** TEMPORARY; true for tables from CREATE TEMPORARY TABLE. */
270constexpr uint32_t DICT_TF2_TEMPORARY = 1;
271
272/** The table has an internal defined DOC ID column */
273constexpr uint32_t DICT_TF2_FTS_HAS_DOC_ID = 2;
274
275/** The table has an FTS index */
276constexpr uint32_t DICT_TF2_FTS = 4;
277
278/** Need to add Doc ID column for FTS index build.
279This is a transient bit for index build */
280constexpr uint32_t DICT_TF2_FTS_ADD_DOC_ID = 8;
281
282/** This bit is used during table creation to indicate that it will
283use its own tablespace instead of the system tablespace. */
284constexpr uint32_t DICT_TF2_USE_FILE_PER_TABLE = 16;
285
286/** Set when we discard/detach the tablespace */
287constexpr uint32_t DICT_TF2_DISCARDED = 32;
288
289/** Intrinsic table bit
290Intrinsic table is table created internally by MySQL modules viz. Optimizer,
291FTS, etc.... Intrinsic table has all the properties of the normal table except
292it is not created by user and so not visible to end-user. */
293constexpr uint32_t DICT_TF2_INTRINSIC = 128;
294
295/** Encryption table bit for innodb_file-per-table only. */
296constexpr uint32_t DICT_TF2_ENCRYPTION_FILE_PER_TABLE = 256;
297
298/** FTS AUX hidden table bit. */
299constexpr uint32_t DICT_TF2_AUX = 512;
300
301/** Table is opened by resurrected trx during crash recovery. */
302constexpr uint32_t DICT_TF2_RESURRECT_PREPARED = 1024;
303/** @} */
304
305/** Tables could be chained together with Foreign key constraint. When
306first load the parent table, we would load all of its descedents.
307This could result in rescursive calls and out of stack error eventually.
308DICT_FK_MAX_RECURSIVE_LOAD defines the maximum number of recursive loads,
309when exceeded, the child table will not be loaded. It will be loaded when
310the foreign constraint check needs to be run. */
311constexpr uint32_t DICT_FK_MAX_RECURSIVE_LOAD = 20;
312
313/** Similarly, when tables are chained together with foreign key constraints
314with on cascading delete/update clause, delete from parent table could
315result in recursive cascading calls. This defines the maximum number of
316such cascading deletes/updates allowed. When exceeded, the delete from
317parent table will fail, and user has to drop excessive foreign constraint
318before proceeds. */
319constexpr uint32_t FK_MAX_CASCADE_DEL = 15;
320
321/** Adds a virtual column definition to a table.
322@param[in,out] table table
323@param[in] heap temporary memory heap, or NULL. It is
324 used to store name when we have not finished
325 adding all columns. When all columns are
326 added, the whole name will copy to memory from
327 table->heap
328@param[in] name column name
329@param[in] mtype main datatype
330@param[in] prtype precise type
331@param[in] len length
332@param[in] pos position in a table
333@param[in] num_base number of base columns
334@param[in] is_visible True if virtual column is visible to user
335@return the virtual column definition */
337 const char *name, ulint mtype,
338 ulint prtype, ulint len, ulint pos,
339 ulint num_base, bool is_visible);
340
341/** Adds a stored column definition to a table.
342@param[in,out] table table
343@param[in] num_base number of base columns. */
345
346/** Renames a column of a table in the data dictionary cache.
347@param[in,out] table Table
348@param[in] nth_col Column index
349@param[in] from Old column name
350@param[in] to New column name
351@param[in] is_virtual If this is a virtual column */
353 const char *from, const char *to,
354 bool is_virtual);
355
356/** This function poplulates a dict_index_t index memory structure with
357supplied information.
358@param[out] index index to be filled
359@param[in] heap memory heap
360@param[in] table_name table name
361@param[in] index_name index name
362@param[in] space space where the index tree is placed, the
363 clustered type ignored if the index is of
364the clustered type
365@param[in] type DICT_UNIQUE, DICT_CLUSTERED, ... ORed
366@param[in] n_fields number of fields */
367static inline void dict_mem_fill_index_struct(
368 dict_index_t *index, mem_heap_t *heap, const char *table_name,
369 const char *index_name, ulint space, ulint type, ulint n_fields);
370
371/** Frees an index memory object. */
372void dict_mem_index_free(dict_index_t *index); /*!< in: index */
373/** Creates and initializes a foreign constraint memory object.
374 @return own: foreign constraint struct */
376
377/** Sets the foreign_table_name_lookup pointer based on the value of
378 lower_case_table_names. If that is 0 or 1, foreign_table_name_lookup
379 will point to foreign_table_name. If 2, then another string is
380 allocated from the heap and set to lower case. */
382 dict_foreign_t *foreign, /*!< in/out: foreign struct */
383 bool do_alloc); /*!< in: is an alloc needed */
384
385/** Sets the referenced_table_name_lookup pointer based on the value of
386 lower_case_table_names. If that is 0 or 1, referenced_table_name_lookup
387 will point to referenced_table_name. If 2, then another string is
388 allocated from the heap and set to lower case. */
390 dict_foreign_t *foreign, /*!< in/out: foreign struct */
391 bool do_alloc); /*!< in: is an alloc needed */
392
393/** Fills the dependent virtual columns in a set.
394Reason for being dependent are
3951) FK can be present on base column of virtual columns
3962) FK can be present on column which is a part of virtual index
397@param[in,out] foreign foreign key information. */
399
400/** Fill virtual columns set in each fk constraint present in the table.
401@param[in,out] table innodb table object. */
403
404/** Free the vcol_set from all foreign key constraint on the table.
405@param[in,out] table innodb table object. */
407
408/** Create a temporary tablename like "#sql-ibtid-inc" where
409 tid = the Table ID
410 inc = a randomly initialized number that is incremented for each file
411The table ID is a 64 bit integer, can use up to 20 digits, and is
412initialized at bootstrap. The second number is 32 bits, can use up to 10
413digits, and is initialized at startup to a randomly distributed number.
414It is hoped that the combination of these two numbers will provide a
415reasonably unique temporary file name.
416@param[in] heap A memory heap
417@param[in] dbtab Table name in the form database/table name
418@param[in] id Table id
419@return A unique temporary tablename suitable for InnoDB use */
420char *dict_mem_create_temporary_tablename(mem_heap_t *heap, const char *dbtab,
421 table_id_t id);
422
423static inline bool is_valid_row_version(const row_version_t version) {
424 /* NOTE : 0 is also a valid row versions for rows which are inserted after
425 upgrading from earlier INSTANT implemenation */
426 if (std::cmp_less_equal(version, MAX_ROW_VERSION)) {
427 return true;
428 }
429
430 return false;
431}
432
433/** Initialize dict memory variables */
434void dict_mem_init(void);
435
436/** SQL identifier name wrapper for pretty-printing */
438 public:
439 /** Default constructor */
441 /** Constructor
442 @param[in] name identifier to assign */
443 explicit id_name_t(const char *name) : m_name(name) {}
444
445 /** Assignment operator
446 @param[in] name identifier to assign */
447 id_name_t &operator=(const char *name) {
448 m_name = name;
449 return (*this);
450 }
451
452 /** Implicit type conversion
453 @return the name */
454 operator const char *() const { return (m_name); }
455
456 /** Explicit type conversion
457 @return the name */
458 const char *operator()() const { return (m_name); }
459
460 private:
461 /** The name in internal representation */
462 const char *m_name;
463};
464
465/** Table name wrapper for pretty-printing */
467 /** The name in internal representation */
468 char *m_name;
469};
470
471/** Data structure for default value of a column in a table */
473 /** Pointer to the column itself */
475 /** Default value in bytes */
476 byte *value;
477 /** Length of default value */
478 size_t len;
479
480 bool operator==(const dict_col_default_t &other) const;
481 bool operator!=(const dict_col_default_t &other) const;
482};
483
484/** Data structure for a column in a table */
486 /*----------------------*/
487 /** The following are copied from dtype_t,
488 so that all bit-fields can be packed tightly. */
489 /** @{ */
490
491 /** Default value when this column was added instantly.
492 If this is not a instantly added column then this is nullptr. */
494
495 unsigned prtype : 32; /*!< precise type; MySQL data
496 type, charset code, flags to
497 indicate nullability,
498 signedness, whether this is a
499 binary string, whether this is
500 a true VARCHAR where MySQL
501 uses 2 bytes to store the length */
502 unsigned mtype : 8; /*!< main data type */
503
504 /* the remaining fields do not affect alphabetical ordering: */
505
506 unsigned len : 16; /*!< length; for MySQL data this
507 is field->pack_length(),
508 except that for a >= 5.0.3
509 type true VARCHAR this is the
510 maximum byte length of the
511 string data (in addition to
512 the string, MySQL uses 1 or 2
513 bytes to store the string length) */
514
515 unsigned mbminmaxlen : 5; /*!< minimum and maximum length of a
516 character, in bytes;
517 DATA_MBMINMAXLEN(mbminlen,mbmaxlen);
518 mbminlen=DATA_MBMINLEN(mbminmaxlen);
519 mbmaxlen=DATA_MBMINLEN(mbminmaxlen) */
520 /*----------------------*/
521 /* End of definitions copied from dtype_t */
522 /** @} */
523
524 unsigned ind : 10; /*!< table column position
525 (starting from 0) */
526 unsigned ord_part : 1; /*!< nonzero if this column
527 appears in the ordering fields
528 of an index */
529 unsigned max_prefix : 12; /*!< maximum index prefix length on
530 this column. Our current max limit is
531 3072 (REC_VERSION_56_MAX_INDEX_COL_LEN)
532 bytes. */
533
534 /* True, if the column is visible */
536
537 private:
538 /* Position of column on physical row.
539 If column prefix is part of PK, it appears twice on row. First 2 bytes are
540 for prefix position and next 2 bytes are for column position on row. */
542
543 /* Row version in which this column was added INSTANTly to the table */
545
546 /* Row version in which this column was dropped INSTANTly from the table */
548
549 public:
550 /* If column prefix is there on row. */
551 bool has_prefix_phy_pos() const { return (phy_pos & 0x8000); }
552
553 /* Get the physical position of column prefix on row. */
554 uint16_t get_prefix_phy_pos() const {
556 return ((uint16_t)(phy_pos >> 16));
557 }
558
559 /* Set the physical position of column prefix on row. */
560 void set_prefix_phy_pos(uint16_t prefix_pos) {
561 phy_pos = prefix_pos;
562 phy_pos = phy_pos << 16;
563 phy_pos |= 0x8000;
564 }
565
566 /* Get the physical position of column on row. */
567 uint16_t get_col_phy_pos() const { return ((phy_pos & ~0x8000) & 0xFFFF); }
568
569 /* Set the physical position of column on row. */
570 void set_col_phy_pos(uint16_t pos) {
572 phy_pos |= pos;
573 }
574
575 /* Set the physical position metadata of column. */
576 uint32_t get_phy_pos() const { return phy_pos; }
577
578 /* Get the physical position metadata of column. */
579 void set_phy_pos(uint32_t pos) { phy_pos = pos; }
580
581 bool is_instant_added() const {
583 return true;
584 }
585 return false;
586 }
587
590 return version_added;
591 }
592
596 }
597
598 bool is_version_added_match(const dict_col_t *col) const {
599 if (is_instant_added() != col->is_instant_added()) {
600 return false;
601 }
602
603 if (is_instant_added()) {
604 return (get_version_added() == col->get_version_added());
605 }
606
607 return true;
608 }
609
610 bool is_instant_dropped() const {
612 return true;
613 }
614 return false;
615 }
616
619 return version_dropped;
620 }
621
625 }
626
627 bool is_version_dropped_match(const dict_col_t *col) const {
628 if (is_instant_dropped() != col->is_instant_dropped()) {
629 return false;
630 }
631
632 if (is_instant_dropped()) {
633 return (get_version_dropped() == col->get_version_dropped());
634 }
635
636 return true;
637 }
638
639 /** Returns the minimum size of the column.
640 @return minimum size */
643 }
644
645 /** Returns the maximum size of the column.
646 @return maximum size */
648
649 /** Check if a column is a virtual column
650 @return true if it is a virtual column, false otherwise */
651 bool is_virtual() const { return (prtype & DATA_VIRTUAL); }
652
653 /** Check if a column is a multi-value virtual column
654 @return true if it is a multi-value virtual column, false otherwise */
655 bool is_multi_value() const { return ((prtype & DATA_MULTI_VALUE) != 0); }
656
657 /** Check if a column is nullable
658 @return true if it is nullable, otherwise false */
659 bool is_nullable() const { return ((prtype & DATA_NOT_NULL) == 0); }
660
661 /** Gets the column data type.
662 @param[out] type data type */
663 void copy_type(dtype_t *type) const {
664 ut_ad(type != nullptr);
665
666 type->mtype = mtype;
667 type->prtype = prtype;
668 type->len = len;
669 type->mbminmaxlen = mbminmaxlen;
670 }
671
672 /** Gets the minimum number of bytes per character.
673 @return minimum multi-byte char size, in bytes */
675
676 /** Gets the maximum number of bytes per character.
677 @return maximum multi-byte char size, in bytes */
679
680 /** Sets the minimum and maximum number of bytes per character.
681 @param[in] mbminlen minimum multi byte character size, in bytes
682 @param[in] mbmaxlen mAXimum multi-byte character size, in bytes */
683 void set_mbminmaxlen(ulint mbminlen, ulint mbmaxlen) {
684 ut_ad(mbminlen < DATA_MBMAX);
685 ut_ad(mbmaxlen < DATA_MBMAX);
686 ut_ad(mbminlen <= mbmaxlen);
687
688 mbminmaxlen = DATA_MBMINMAXLEN(mbminlen, mbmaxlen);
689 }
690
691 /** Returns the size of a fixed size column, 0 if not a fixed size column.
692 @param[in] comp nonzero=ROW_FORMAT=COMPACT
693 @return fixed size, or 0 */
696 }
697
698 /** Returns the ROW_FORMAT=REDUNDANT stored SQL NULL size of a column.
699 For fixed length types it is the fixed length of the type, otherwise 0.
700 @param[in] comp nonzero=ROW_FORMAT=COMPACT
701 @return SQL null storage size in ROW_FORMAT=REDUNDANT */
702 ulint get_null_size(ulint comp) const { return (get_fixed_size(comp)); }
703
704 /** Check whether the col is used in spatial index or regular index.
705 @return spatial status */
707 spatial_status_t spatial_status = SPATIAL_NONE;
708
709 /* Column is not a part of any index. */
710 if (!ord_part) {
711 return (spatial_status);
712 }
713
715 if (max_prefix == 0) {
716 spatial_status = SPATIAL_ONLY;
717 } else {
718 /* Any regular index on a geometry column
719 should have a prefix. */
720 spatial_status = SPATIAL_MIXED;
721 }
722 }
723
724 return (spatial_status);
725 }
726
727 /** Set default value
728 @param[in] value Default value
729 @param[in] length Default value length
730 @param[in,out] heap Heap to allocate memory */
731 void set_default(const byte *value, size_t length, mem_heap_t *heap);
732
733 /** Check if column is dropped before the given version.
734 @param[in] version row version
735 @return true if the column is dropped before or in the version. */
738
739 if (!is_instant_dropped()) {
740 return false;
741 }
742
743 return (get_version_dropped() <= version);
744 }
745
746 /** Check if column is added after the current version.
747 @param[in] version row version
748 @return true if column is added after the current row version. */
751
752 if (!is_instant_added()) {
753 return false;
754 }
755
756 return (get_version_added() > version);
757 }
758
759 /** Check if a column is visible in given version.
760 @param[in] version row version
761 return true if column is visible in version. */
765 }
766
767#ifdef UNIV_DEBUG
768 /** Assert that a column and a data type match.
769 param[in] type data type
770 @return true */
771 bool assert_equal(const dtype_t *type) const {
772 ut_ad(type);
773
774 ut_ad_eq(mtype, type->mtype);
775 ut_ad_eq((prtype | DATA_VIRTUAL), (type->prtype | DATA_VIRTUAL));
776 // ut_ad(col->len == type->len);
777#ifndef UNIV_HOTBACKUP
778 ut_ad(mbminmaxlen == type->mbminmaxlen);
779#endif /* !UNIV_HOTBACKUP */
780
781 return true;
782 }
783
784 /** Check if a column name resembles format for dropped column.
785 param[in] type column name
786 @return true if column name resembles dropped column. */
787 static bool is_instant_dropped_name(const std::string col_name) {
788 if (col_name.find(INSTANT_DROP_SUFFIX_8_0_29) != std::string::npos ||
789 col_name.find(INSTANT_DROP_PREFIX_8_0_32) != std::string::npos)
790 return true;
791 return false;
792 }
793#endif /* UNIV_DEBUG */
794};
795
796/** Index information put in a list of virtual column structure. Index
797id and virtual column position in the index will be logged.
798There can be multiple entries for a given index, with a different position. */
800 /** active index on the column */
802
803 /** position in this index */
805};
806
807/** Index list to put in dict_v_col_t */
808typedef std::list<dict_v_idx_t, ut::allocator<dict_v_idx_t>> dict_v_idx_list;
809
810/** Data structure for a virtual column in a table */
812 /** column structure */
814
815 /** array of base column ptr */
817
818 /** number of base columns */
820
821 /** column pos in table */
823
824 /** Virtual index list, and column position in the index,
825 the allocated memory is not from table->heap, nor it is
826 tracked by dict_sys->size */
828};
829
830/** Data structure for newly added virtual column in a table */
832 /** number of new virtual column */
834
835 /** column structures */
837
838 /** new col names */
839 const char **v_col_name;
840};
841
842/** Data structure for a stored column in a table. */
844 /** Stored column ptr */
846 /** array of base col ptr */
848 /** number of base columns */
850 /** column pos in table */
852};
853
854/** list to put stored column for dict_table_t */
855typedef std::list<dict_s_col_t, ut::allocator<dict_s_col_t>> dict_s_col_list;
856
857/** @brief DICT_ANTELOPE_MAX_INDEX_COL_LEN is measured in bytes and
858is the maximum indexed column length (or indexed prefix length) in
859ROW_FORMAT=REDUNDANT and ROW_FORMAT=COMPACT. Also, in any format,
860any fixed-length field that is longer than this will be encoded as
861a variable-length field.
862
863It is set to 3*256, so that one can create a column prefix index on
864256 characters of a TEXT or VARCHAR column also in the UTF-8
865charset. In that charset, a character may take at most 3 bytes. This
866constant MUST NOT BE CHANGED, or the compatibility of InnoDB data
867files would be at risk! */
870
871/** Find out maximum indexed column length by its table format.
872For ROW_FORMAT=REDUNDANT and ROW_FORMAT=COMPACT, the maximum
873field length is REC_ANTELOPE_MAX_INDEX_COL_LEN - 1 (767). For
874ROW_FORMAT=COMPRESSED and ROW_FORMAT=DYNAMIC, the length could
875be REC_VERSION_56_MAX_INDEX_COL_LEN (3072) bytes */
876#define DICT_MAX_FIELD_LEN_BY_FORMAT(table) \
877 (dict_table_has_atomic_blobs(table) ? REC_VERSION_56_MAX_INDEX_COL_LEN \
878 : REC_ANTELOPE_MAX_INDEX_COL_LEN - 1)
879
880static inline uint32_t DICT_MAX_FIELD_LEN_BY_FORMAT_FLAG(uint32_t flags) {
883 }
885}
886
887/** Defines the maximum fixed length column size */
889
890/** Data structure for a field in an index */
893
894 dict_col_t *col; /*!< pointer to the table column */
895 id_name_t name; /*!< name of the column */
896 unsigned prefix_len : 12; /*!< 0 or the length of the column
897 prefix in bytes in a MySQL index of
898 type, e.g., INDEX (textcol(25));
899 must be smaller than
900 DICT_MAX_FIELD_LEN_BY_FORMAT;
901 NOTE that in the UTF-8 charset, MySQL
902 sets this to (mbmaxlen * the prefix len)
903 in UTF-8 chars */
904 unsigned fixed_len : 10; /*!< 0 or the fixed length of the
905 column if smaller than
906 DICT_ANTELOPE_MAX_INDEX_COL_LEN */
907 unsigned is_ascending : 1; /*!< 0=DESC, 1=ASC */
908
909 uint16_t get_phy_pos() const {
910 if (prefix_len != 0) {
911 return col->get_prefix_phy_pos();
912 }
913
914 return col->get_col_phy_pos();
915 }
916};
917
918/** PADDING HEURISTIC BASED ON LINEAR INCREASE OF PADDING TO AVOID
919 COMPRESSION FAILURES
920 (Note: this is relevant only for compressed indexes)
921 GOAL: Avoid compression failures by maintaining information about the
922 compressibility of data. If data is not very compressible then leave
923 some extra space 'padding' in the uncompressed page making it more
924 likely that compression of less than fully packed uncompressed page will
925 succeed.
926
927 This padding heuristic works by increasing the pad linearly until the
928 desired failure rate is reached. A "round" is a fixed number of
929 compression operations.
930 After each round, the compression failure rate for that round is
931 computed. If the failure rate is too high, then padding is incremented
932 by a fixed value, otherwise it's left intact.
933 If the compression failure is lower than the desired rate for a fixed
934 number of consecutive rounds, then the padding is decreased by a fixed
935 value. This is done to prevent overshooting the padding value,
936 and to accommodate the possible change in data compressibility. */
937
938/** Number of zip ops in one round. */
939constexpr uint32_t ZIP_PAD_ROUND_LEN = 128;
940
941/** Number of successful rounds after which the padding is decreased */
942constexpr uint32_t ZIP_PAD_SUCCESSFUL_ROUND_LIMIT = 5;
943
944/** Amount by which padding is increased. */
945constexpr uint32_t ZIP_PAD_INCR = 128;
946
947/** Percentage of compression failures that are allowed in a single
948round */
949extern ulong zip_failure_threshold_pct;
950
951/** Maximum percentage of a page that can be allowed as a pad to avoid
952compression failures */
953extern ulong zip_pad_max;
954
955/** Data structure to hold information about about how much space in
956an uncompressed page should be left as padding to avoid compression
957failures. This estimate is based on a self-adapting heuristic. */
959 SysMutex *mutex; /*!< mutex protecting the info */
960 std::atomic<ulint> pad; /*!< number of bytes used as pad */
961 ulint success; /*!< successful compression ops during
962 current round */
963 ulint failure; /*!< failed compression ops during
964 current round */
965 ulint n_rounds; /*!< number of currently successful
966 rounds */
967#ifndef UNIV_HOTBACKUP
968 std::atomic<os_once::state_t> mutex_created;
969 /*!< Creation state of mutex member */
970#endif /* !UNIV_HOTBACKUP */
971};
972
973/** If key is fixed length key then cache the record offsets on first
974computation. This will help save computation cycle that generate same
975redundant data. */
977 /** Holds reference to cached offsets for record. */
978 const ulint *offsets{nullptr};
979
980 /** Number of NULLable columns among those for which offsets are cached */
981 size_t nullable_cols{0};
982};
983
984/** Cache position of last inserted or selected record by caching record
985and holding reference to the block where record resides.
986Note: We don't commit mtr and hold it beyond a transaction lifetime as this is
987a special case (intrinsic table) that are not shared across connection. */
989 public:
990 /** Constructor */
992 /* Do Nothing. */
993 }
994
995 /* Commit mtr and re-initialize cache record and block to NULL. */
996 void release() {
997 if (mtr.is_active()) {
998 mtr_commit(&mtr);
999 }
1000 rec = nullptr;
1001 block = nullptr;
1002 invalid = false;
1003 }
1004
1005 public:
1006 /** last inserted/selected record. */
1008
1009 /** block where record reside. */
1011
1012 /** active mtr that will be re-used for next insert/select. */
1014
1015 /** disable caching. (disabled when table involves blob/text.) */
1017
1018 /** If index structure is undergoing structural change viz.
1019 split then invalidate the cached position as it would be no more
1020 remain valid. Will be re-cached on post-split insert. */
1022};
1023
1024/** Data structure storing index statistics for query optimization. */
1026#ifndef UNIV_HOTBACKUP
1027 /** approximate number of different key values for this index, for each
1028 n-column prefix where 1 <= n <= dict_get_n_unique(index) (the array is
1029 indexed from 0 to n_uniq-1); we periodically calculate new estimates */
1031
1032 /** number of pages that were sampled to calculate each of
1033 n_diff_key_vals[], e.g. stat_n_sample_sizes[3] pages were sampled to get
1034 the number n_diff_key_vals[3]. */
1036
1037 /* approximate number of non-null key values for this index, for each column
1038 where 1 <= n <= dict_get_n_unique(index) (the array is indexed from 0 to
1039 n_uniq-1); This is used when innodb_stats_method is "nulls_ignored". */
1041
1042 /** approximate index size in database pages */
1044#endif /* !UNIV_HOTBACKUP */
1045 /** approximate number of leaf pages in the index tree */
1047};
1048
1049/** "GEN_CLUST_INDEX" is the name reserved for InnoDB default
1050system clustered index when there is no primary key. */
1051const char innobase_index_reserve_name[] = "GEN_CLUST_INDEX";
1052
1053namespace dd {
1054class Spatial_reference_system;
1055}
1056
1057#ifdef UNIV_DEBUG
1058/** Value of dict_index_t::magic_n */
1059constexpr uint32_t DICT_INDEX_MAGIC_N = 76789786;
1060#endif
1061
1063constexpr uint32_t MAX_KEY_LENGTH_BITS = 12;
1064
1065/** Data structure for an index. Most fields will be
1066initialized to 0, NULL or false in dict_mem_index_create(). */
1068 /** id of the index */
1070
1071 /** memory heap */
1073
1074 /** index name */
1076
1077 /** table name */
1078 const char *table_name;
1079
1080 /** back pointer to table */
1082
1083 /** space where the index tree is placed */
1084 unsigned space : 32;
1085
1086 /** index tree root page number */
1087 unsigned page : 32;
1088
1089 /** In the pessimistic delete, if the page data size drops below this limit
1090 in percent, merging it to a neighbor is tried */
1091 unsigned merge_threshold : 6;
1092
1093 /** index type (DICT_CLUSTERED, DICT_UNIQUE, DICT_IBUF, DICT_CORRUPT) */
1094 unsigned type : DICT_IT_BITS;
1095
1096 /** position of the trx id column in a clustered index record, if the fields
1097 before it are known to be of a fixed size, 0 otherwise */
1099
1100 static_assert(1 << MAX_KEY_LENGTH_BITS >= MAX_KEY_LENGTH,
1101 "1<<MAX_KEY_LENGTH_BITS) < MAX_KEY_LENGTH");
1102
1103 /** number of columns the user defined to be in the index: in the internal
1104 representation we add more columns */
1105 unsigned n_user_defined_cols : 10;
1106
1107 /** if true, allow duplicate values even if index is created with unique
1108 constraint */
1109 unsigned allow_duplicates : 1;
1110
1111 /** if true, SQL NULL == SQL NULL */
1112 unsigned nulls_equal : 1;
1113
1114 /** if true, then disable AHI. Currently limited to intrinsic temporary table
1115 and SDI table as index id is not unique for such table which is one of the
1116 validation criterion for ahi. */
1117 unsigned disable_ahi : 1;
1118
1119 /** number of fields from the beginning which are enough to determine an index
1120 entry uniquely */
1121 unsigned n_uniq : 10;
1122
1123 /** number of fields defined so far */
1124 unsigned n_def : 10;
1125
1126 /** number of fields in the index */
1127 unsigned n_fields : 10;
1128
1129 /** number of total fields in the index (including INSTANT dropped fields) */
1130 unsigned n_total_fields : 10;
1131
1132 /** number of nullable fields */
1133 unsigned n_nullable : 10;
1134
1135 /** number of nullable fields before first instant ADD COLUMN applied to this
1136 table. This is valid only when has_instant_cols() is true */
1137 unsigned n_instant_nullable : 10;
1138
1139 /** true if the index object is in the dictionary cache */
1140 unsigned cached : 1;
1141
1142 /** true if the index is to be dropped; protected by dict_operation_lock */
1143 unsigned to_be_dropped : 1;
1144
1145 /** enum online_index_status. Transitions from ONLINE_INDEX_COMPLETE (to
1146 ONLINE_INDEX_CREATION) are protected by dict_operation_lock and
1147 dict_sys->mutex. Other changes are protected by index->lock. */
1148 unsigned online_status : 2;
1149
1150 /** a flag that is set for secondary indexes that have not been committed to
1151 the data dictionary yet */
1152 unsigned uncommitted : 1;
1153
1154 /** true if the index is clustered index and it has some instant columns */
1155 unsigned instant_cols : 1;
1156
1157 /** true if the index is clustered index and table has row versions */
1158 unsigned row_versions : 1;
1159
1160 /** spatial reference id */
1161 uint32_t srid;
1162
1163 /** says whether SRID is valid - it cane be undefined */
1165
1166 /** Cached spatial reference system dictionary entry used by R-tree indexes.
1167 */
1168 std::unique_ptr<dd::Spatial_reference_system> rtr_srs;
1169
1170#ifdef UNIV_DEBUG
1171 uint32_t magic_n; /*!< magic number */
1172#endif
1173
1174 /** array of field descriptions */
1176
1177 /** Array of field pos sorted as per their physical pos in record. Only
1178 needed for clustered index having INSTANT ADD/DROP columns. */
1179 std::vector<uint16_t> fields_array;
1180
1181 /** Number of nullable columns in each version. Only needed for clustered
1182 index having INSTANT ADD/DROP columns. */
1183 uint32_t nullables[MAX_ROW_VERSION + 1] = {0};
1184
1185#ifndef UNIV_HOTBACKUP
1186 /** fulltext parser plugin */
1188
1189 /** true if it's ngram parser */
1191
1192 /** whether it has a newly added virtual column in ALTER */
1194
1195 /** if the index is an hidden index */
1197#endif /* !UNIV_HOTBACKUP */
1198
1199 /** list of indexes of the table */
1201
1202 /** info used in optimistic searches */
1204
1205#ifndef UNIV_HOTBACKUP
1206 /** the log of modifications during online index creation;
1207 valid when online_status is ONLINE_INDEX_CREATION */
1209#endif /* !UNIV_HOTBACKUP */
1210
1211 /*----------------------*/
1212 /** Statistics for query optimization */
1213 /** @{ */
1215 /** @} */
1216
1217 /** cache the last insert position. Currently limited to auto-generated
1218 clustered index on intrinsic table only. */
1220
1221 /** cache the last selected position. Currently limited to intrinsic table
1222 only. */
1224
1225 /** cache the field that needs to be re-computed on each insert. Limited to
1226 intrinsic table as this is common share and can't be used without protection
1227 if table is accessible to multiple-threads. */
1229
1230 /** Node sequence number for RTree */
1232
1233 /** tracking all R-Tree search cursors */
1235
1236 /** id of the transaction that created this index, or 0 if the index existed
1237 when InnoDB was started up */
1239
1240 /** Information about state of compression failures and successes */
1242
1243 /** read-write lock protecting the upper levels of the index tree */
1245
1246 /** Flag whether need to fill dd tables when it's a fulltext index. */
1248
1249 /** Set instant nullable
1250 @param[in] n nullable fields before first INSTANT ADD */
1252
1253 /** Get instant nullable.
1254 @return number of nullable fields before first INSTANT ADD */
1255 uint16_t get_instant_nullable() const { return n_instant_nullable; }
1256
1257 /** Get the nullable fields before any INSTANT ADD/DROP
1258 @return number of nullable fields */
1260 if (has_instant_cols()) {
1261 return get_instant_nullable();
1262 }
1263
1264 if (has_row_versions()) {
1265 return get_nullable_in_version(0);
1266 }
1267
1268 return n_nullable;
1269 }
1270
1271 /** Determine if the index has been committed to the
1272 data dictionary.
1273 @return whether the index definition has been committed */
1274 bool is_committed() const {
1276 return (UNIV_LIKELY(!uncommitted));
1277 }
1278
1279 /** Flag an index committed or uncommitted.
1280 @param[in] committed whether the index is committed */
1281 void set_committed(bool committed) {
1283 ut_ad(committed || !(type & DICT_CLUSTERED));
1284 uncommitted = !committed;
1285 }
1286
1287 /** Get the next index.
1288 @return next index
1289 @retval NULL if this was the last index */
1290 const dict_index_t *next() const {
1291 const dict_index_t *next = UT_LIST_GET_NEXT(indexes, this);
1293 return (next);
1294 }
1295 /** Get the next index.
1296 @return next index
1297 @retval NULL if this was the last index */
1299 return (const_cast<dict_index_t *>(
1300 const_cast<const dict_index_t *>(this)->next()));
1301 }
1302
1303 /** Check whether the index is corrupted.
1304 @return true if index is corrupted, otherwise false */
1305 bool is_corrupted() const {
1307
1308 return (type & DICT_CORRUPT);
1309 }
1310
1311 /* Check whether the index is the clustered index
1312 @return nonzero for clustered index, zero for other indexes */
1313
1314 bool is_clustered() const {
1316
1317 return (type & DICT_CLUSTERED);
1318 }
1319
1320 /** Check whether the index is the multi-value index
1321 @return nonzero for multi-value index, zero for other indexes */
1322 bool is_multi_value() const {
1324
1325 return (type & DICT_MULTI_VALUE);
1326 }
1327
1328 /** Returns the minimum data size of an index record.
1329 @return minimum data size in bytes */
1331 ulint size = 0;
1332
1333 for (unsigned i = 0; i < n_fields; i++) {
1334 size += get_col(i)->get_min_size();
1335 }
1336
1337 return (size);
1338 }
1339
1340 /** Check whether index can be used by transaction
1341 @param[in] trx transaction*/
1342 bool is_usable(const trx_t *trx) const;
1343
1344 /** Check whether index has any instantly added columns.
1345 Possible only if table has INSTANT ADD columns and is upgraded.
1346 @return true if this is instant affected, otherwise false */
1347 bool has_instant_cols() const { return (instant_cols); }
1348
1349 /** Check whether index belongs to a table having row versions
1350 @return true if table has row versions, otherwise false */
1351 bool has_row_versions() const { return (row_versions); }
1352
1353 /** check if either instant or versioned.
1354 @return true if table has row versions or instant cols, otherwise false */
1356 if (!is_clustered()) {
1358 return false;
1359 }
1360
1361 return (has_row_versions() || has_instant_cols());
1362 }
1363
1364 /** Check if tuple is having instant format.
1365 @param[in] n_fields_in_tuple number of fields in tuple
1366 @return true if yes, false otherwise. */
1367 bool is_tuple_instant_format(const uint16_t n_fields_in_tuple) const;
1368
1369 /** Returns the number of nullable fields before specified nth field
1370 @param[in] nth nth field to check */
1371 uint32_t get_n_nullable_before(uint32_t nth) const {
1372 uint32_t nullable = 0;
1373 ut_ad(nth <= n_total_fields);
1374
1375 for (size_t i = 0; i < nth; ++i) {
1376 dict_col_t *col = get_field(i)->col;
1377
1378 ut_ad(!col->is_instant_dropped());
1379
1380 if (col->is_nullable()) {
1381 nullable++;
1382 }
1383 }
1384
1385 return (nullable);
1386 }
1387
1388 /** Returns total fields including INSTANT DROP fields. */
1389 uint32_t get_n_total_fields() const {
1391 return n_total_fields;
1392 }
1393
1394 /** Returns the number of fields before first instant ADD COLUMN. This is
1395 needed only for V1 INSTANT ADD. */
1396 uint32_t get_instant_fields() const;
1397
1398 size_t calculate_n_instant_nullable(size_t _n_fields) const {
1399 if (!has_row_versions()) {
1401 return get_n_nullable_before(_n_fields);
1402 }
1403
1404 size_t n_drop_nullable_cols = 0;
1405 size_t new_n_nullable = 0;
1406 for (size_t i = 0; i < n_def; i++) {
1407 const dict_field_t *field = &fields[i];
1408 const dict_col_t *col = field->col;
1409
1410 if (col->is_instant_added()) {
1411 continue;
1412 }
1413
1414 if (col->is_instant_dropped()) {
1415 if (col->get_col_phy_pos() < _n_fields && col->is_nullable()) {
1416 n_drop_nullable_cols++;
1417 }
1418 continue;
1419 }
1420
1421 /* This is regular column */
1422 if (col->get_col_phy_pos() < _n_fields) {
1423 if (col->is_nullable()) {
1424 new_n_nullable++;
1425 }
1426 }
1427 }
1428
1429 new_n_nullable += n_drop_nullable_cols;
1430
1431 return new_n_nullable;
1432 }
1433
1434 /** Create nullables array.
1435 @param[in] current_row_version current row version of table */
1436 void create_nullables(uint32_t current_row_version);
1437
1438 /** Return nullable in a specific row version */
1441
1442 return nullables[version];
1443 }
1444
1445 /** Create fields array sorted by phy_pos of field in row */
1447 fields_array.resize(n_def);
1448 for (uint32_t i = 0; i < n_def; i++) {
1449 dict_field_t *field = get_field(i);
1450 ut_ad(field != nullptr && field->col != nullptr);
1451
1452 size_t pos = field->get_phy_pos();
1453
1454 fields_array[pos] = i;
1455 }
1456 }
1457
1459 /* The dict_index_t destructor is never called. The object is "destructed"
1460 manually in dict_mem_index_free() and then the memory is just freed. This
1461 method is called from the mentioned dict_mem_index_free(). Please note that
1462 this vector is never constructed either - we just zero the memory and start
1463 using it after calling a "constructor" dict_mem_fill_index_struct(). */
1464 fields_array.~vector<uint16_t>();
1465 }
1466
1467 /** Adds a field definition to an index. NOTE: does not take a copy
1468 of the column name if the field is a column. The memory occupied
1469 by the column name may be released only after publishing the index.
1470 @param[in] name_arg column name
1471 @param[in] prefix_len 0 or the column prefix length in a MySQL index
1472 like INDEX (textcol(25))
1473 @param[in] is_ascending true=ASC, false=DESC */
1474 void add_field(const char *name_arg, ulint prefix_len, bool is_ascending) {
1475 dict_field_t *field;
1476
1478
1479 n_def++;
1480
1481 field = get_field(n_def - 1);
1482
1483 field->name = name_arg;
1484 field->prefix_len = (unsigned int)prefix_len;
1485 field->is_ascending = is_ascending;
1486 }
1487
1488 /** Gets the nth physical pos field.
1489 @param[in] pos physical position of the field
1490 @return pointer to the field object. */
1492 ut_ad(pos < n_def);
1494
1495 if (has_row_versions()) {
1496 return get_field(fields_array[pos]);
1497 }
1498
1499 return get_field(pos);
1500 }
1501
1502 /** Gets the nth field of an index.
1503 @param[in] pos position of field
1504 @return pointer to field object */
1506 ut_ad(pos < n_def);
1508
1509 return (fields + pos);
1510 }
1511
1512 /** Given the physical position, find the logical position of field.
1513 @param[in] phy_pos physical position of field
1514 @return logical position of field */
1515 uint16_t get_logical_pos(uint16_t phy_pos) const {
1516 for (size_t i = 0; i < n_def; i++) {
1517 if (get_field(i)->get_phy_pos() == phy_pos) {
1518 return i;
1519 }
1520 }
1521 ut_ad(false);
1522 return UINT16_UNDEFINED;
1523 }
1524
1525 /** Get the physical position of a field on a row. For table having INSTANT
1526 column, it might differ from field index (pos).
1527 @param[in] pos field index
1528 @return physical position on row */
1529 uint16_t get_field_off_pos(ulint pos) const {
1530 return get_field(pos)->get_phy_pos();
1531 }
1532
1534 uint16_t phy_pos = get_field(pos)->get_phy_pos();
1536 return phy_pos;
1537 }
1538
1539 uint16_t res = phy_pos;
1540 for (size_t i = 0; i < phy_pos; i++) {
1541 if (get_field(fields_array[i])->col->is_dropped_in_or_before(version)) {
1542 res--;
1543 }
1544 }
1545
1546 return res;
1547 }
1548
1549 /** Gets pointer to the nth column in an index.
1550 @param[in] pos position of the field
1551 @return column */
1552 const dict_col_t *get_col(ulint pos) const { return (get_field(pos)->col); }
1553
1554 /** Gets the column number the nth field in an index.
1555 @param[in] pos position of the field
1556 @return column number */
1557 ulint get_col_no(ulint pos) const;
1558
1559 /** Returns the position of a system column in an index.
1560 @param[in] type DATA_ROW_ID, ...
1561 @return position, ULINT_UNDEFINED if not contained */
1563
1564 /** Looks for column n in an index.
1565 @param[in] n column number
1566 @param[in] inc_prefix true=consider column prefixes too
1567 @param[in] is_virtual true==virtual column
1568 @return position in internal representation of the index;
1569 ULINT_UNDEFINED if not contained */
1570 ulint get_col_pos(ulint n, bool inc_prefix = false,
1571 bool is_virtual = false) const;
1572
1573 /** Get the default value of nth field and its length if exists.
1574 If not exists, both the return value is nullptr and length is 0.
1575 @param[in] nth nth field to get
1576 @param[in,out] length length of the default value
1577 @return the default value data of nth field */
1578 const byte *get_nth_default(ulint nth, ulint *length) const {
1579 ut_ad(nth < get_n_total_fields());
1580
1581 const dict_col_t *col = get_physical_field(nth)->col;
1582 if (col->instant_default == nullptr) {
1583 *length = 0;
1584 return (nullptr);
1585 }
1586
1587 *length = col->instant_default->len;
1588 ut_ad(*length == 0 || *length == UNIV_SQL_NULL ||
1589 col->instant_default->value != nullptr);
1590 return (col->instant_default->value);
1591 }
1592
1593 /** Sets srid and srid_is_valid values
1594 @param[in] srid_value value of SRID, may be garbage
1595 if srid_is_valid_value = false
1596 @param[in] srid_is_valid_value value of srid_is_valid */
1597 void fill_srid_value(uint32_t srid_value, bool srid_is_valid_value) {
1598 srid_is_valid = srid_is_valid_value;
1599 srid = srid_value;
1600 }
1601
1602 /** Check if the underlying table is compressed.
1603 @return true if compressed, false otherwise. */
1604 inline bool is_compressed() const;
1605
1606 /** Check if a multi-value index is built on specified multi-value
1607 virtual column. Please note that there could be only one multi-value
1608 virtual column on the multi-value index, but not necessary the first
1609 field of the index.
1610 @param[in] mv_col multi-value virtual column
1611 @return non-zero means the column is on the index and this is the
1612 nth position of the column, zero means it's not on the index */
1613 uint32_t has_multi_value_col(const dict_v_col_t *mv_col) const {
1615 for (uint32_t i = 0; i < n_fields; ++i) {
1616 const dict_col_t *col = get_col(i);
1617 if (mv_col->m_col.ind == col->ind) {
1618 return (i + 1);
1619 }
1620
1621 /* Only one multi-value field, if not match then no match. */
1622 if (col->is_multi_value()) {
1623 break;
1624 }
1625 }
1626
1627 return (0);
1628 }
1629
1630 public:
1631 /** Get the page size of the tablespace to which this index belongs.
1632 @return the page size. */
1633 page_size_t get_page_size() const;
1634
1635 /** Get the space id of the tablespace to which this index belongs.
1636 @return the space id. */
1637 space_id_t space_id() const { return space; }
1638
1639 /** Check if it is a full-text search (FTS) index
1640 @return true if this is a FTS index, false otherwise. */
1641 bool is_fts_index() const { return type & DICT_FTS; }
1642};
1643
1644/** The status of online index creation */
1646 /** the index is complete and ready for access */
1648 /** the index is being created, online
1649 (allowing concurrent modifications) */
1651 /** secondary index creation was aborted and the index
1652 should be dropped as soon as index->table->n_ref_count reaches 0,
1653 or online table rebuild was aborted and the clustered index
1654 of the original table should soon be restored to
1655 ONLINE_INDEX_COMPLETE */
1657 /** the online index creation was aborted, the index was
1658 dropped from the data dictionary and the tablespace, and it
1659 should be dropped from the data dictionary cache as soon as
1660 index->table->n_ref_count reaches 0. */
1663
1664/** Set to store the virtual columns which are affected by Foreign
1665key constraint. */
1666typedef std::set<dict_v_col_t *, std::less<dict_v_col_t *>,
1669
1670/** Data structure for a foreign key constraint; an example:
1671FOREIGN KEY (A, B) REFERENCES TABLE2 (C, D). Most fields will be
1672initialized to 0, NULL or false in dict_mem_foreign_create(). */
1674 mem_heap_t *heap; /*!< this object is allocated from
1675 this memory heap */
1676 char *id; /*!< id of the constraint as a
1677 null-terminated string */
1678 unsigned n_fields : 10; /*!< number of indexes' first fields
1679 for which the foreign key
1680 constraint is defined: we allow the
1681 indexes to contain more fields than
1682 mentioned in the constraint, as long
1683 as the first fields are as mentioned */
1684 unsigned type : 6; /*!< 0 or DICT_FOREIGN_ON_DELETE_CASCADE
1685 or DICT_FOREIGN_ON_DELETE_SET_NULL */
1686 char *foreign_table_name; /*!< foreign table name */
1688 /*!< foreign table name used for dict lookup */
1689 dict_table_t *foreign_table; /*!< table where the foreign key is */
1690 const char **foreign_col_names; /*!< names of the columns in the
1691 foreign key */
1692 char *referenced_table_name; /*!< referenced table name */
1694 /*!< referenced table name for dict lookup*/
1695 dict_table_t *referenced_table; /*!< table where the referenced key
1696 is */
1697 const char **referenced_col_names; /*!< names of the referenced
1698 columns in the referenced table */
1699 dict_index_t *foreign_index; /*!< foreign index; we require that
1700 both tables contain explicitly defined
1701 indexes for the constraint: InnoDB
1702 does not generate new indexes
1703 implicitly */
1704 dict_index_t *referenced_index; /*!< referenced index */
1705
1706 dict_vcol_set *v_cols; /*!< set of virtual columns affected
1707 by foreign key constraint. */
1708
1709 /** Check whether foreign key constraint contains a column with a full
1710 index on it. The function is used in the context of cascading DML
1711 operations.
1712 @retval true if the column has FTS index on it.
1713 @retval false if the FK table has no FTS index or has self referential
1714 relationship
1715 */
1716 bool is_fts_col_affected() const;
1717};
1718
1719std::ostream &operator<<(std::ostream &out, const dict_foreign_t &foreign);
1720
1722 dict_foreign_print(std::ostream &out) : m_out(out) {}
1723
1724 void operator()(const dict_foreign_t *foreign) { m_out << *foreign; }
1725
1726 private:
1727 std::ostream &m_out;
1728};
1729
1730/** Compare two dict_foreign_t objects using their ids. Used in the ordering
1731of dict_table_t::foreign_set and dict_table_t::referenced_set. It returns
1732true if the first argument is considered to go before the second in the
1733strict weak ordering it defines, and false otherwise. */
1735 bool operator()(const dict_foreign_t *lhs, const dict_foreign_t *rhs) const {
1736 return (ut_strcmp(lhs->id, rhs->id) < 0);
1737 }
1738};
1739
1740/** A function object to find a foreign key with the given index as the
1741referenced index. Return the foreign key with matching criteria or NULL */
1744
1745 bool operator()(const dict_foreign_t *foreign) const {
1746 return (foreign->referenced_index == m_index);
1747 }
1748
1750};
1751
1752/* A function object to check if the foreign constraint is between different
1753tables. Returns true if foreign key constraint is between different tables,
1754false otherwise. */
1756 bool operator()(const dict_foreign_t *foreign) const {
1757 return (foreign->foreign_table != foreign->referenced_table);
1758 }
1759};
1760
1764
1765std::ostream &operator<<(std::ostream &out, const dict_foreign_set &fk_set);
1766
1767/** Function object to check if a foreign key object is there
1768in the given foreign key set or not. It returns true if the
1769foreign key is not found, false otherwise */
1772
1773 /* Return true if the given foreign key is not found */
1774 bool operator()(dict_foreign_t *const &foreign) const {
1775 return (m_foreigns.find(foreign) == m_foreigns.end());
1776 }
1777
1778 private:
1780};
1781
1782/** Validate the search order in the foreign key set.
1783@param[in] fk_set the foreign key set to be validated
1784@return true if search order is fine in the set, false otherwise. */
1786
1787/** Validate the search order in the foreign key sets of the table
1788(foreign_set and referenced_set).
1789@param[in] table table whose foreign key sets are to be validated
1790@return true if foreign key sets are fine, false otherwise. */
1792
1793/** Frees a foreign key struct. */
1795 dict_foreign_t *foreign) /*!< in, own: foreign key struct */
1796{
1797 if (foreign->v_cols != nullptr) {
1798 ut::delete_(foreign->v_cols);
1799 }
1800
1801 mem_heap_free(foreign->heap);
1802}
1803
1804/** The destructor will free all the foreign key constraints in the set
1805by calling dict_foreign_free() on each of the foreign key constraints.
1806This is used to free the allocated memory when a local set goes out
1807of scope. */
1810 : m_foreign_set(foreign_set) {}
1811
1815 }
1816
1818};
1819
1820/** The flags for ON_UPDATE and ON_DELETE can be ORed; the default is that
1821a foreign key constraint is enforced, therefore RESTRICT just means no flag */
1822/** @{ */
1823/** ON DELETE CASCADE */
1824constexpr uint32_t DICT_FOREIGN_ON_DELETE_CASCADE = 1;
1825/** ON DELETE SET NULL */
1826constexpr uint32_t DICT_FOREIGN_ON_DELETE_SET_NULL = 2;
1827/** ON UPDATE CASCADE */
1828constexpr uint32_t DICT_FOREIGN_ON_UPDATE_CASCADE = 4;
1829/** ON UPDATE SET NULL */
1830constexpr uint32_t DICT_FOREIGN_ON_UPDATE_SET_NULL = 8;
1831/** ON DELETE NO ACTION */
1832constexpr uint32_t DICT_FOREIGN_ON_DELETE_NO_ACTION = 16;
1833/** ON UPDATE NO ACTION */
1834constexpr uint32_t DICT_FOREIGN_ON_UPDATE_NO_ACTION = 32;
1835/** @} */
1836
1837/** Display an identifier.
1838@param[in,out] s output stream
1839@param[in] id_name SQL identifier (other than table name)
1840@return the output stream */
1841std::ostream &operator<<(std::ostream &s, const id_name_t &id_name);
1842
1843/** Display a table name.
1844@param[in,out] s output stream
1845@param[in] table_name table name
1846@return the output stream */
1847std::ostream &operator<<(std::ostream &s, const table_name_t &table_name);
1848
1849#ifndef UNIV_HOTBACKUP
1850/** List of locks that different transactions have acquired on a table. This
1851list has a list node that is embedded in a nested union/structure. We have to
1852generate a specific template for it. */
1853struct TableLockGetNode;
1855#endif /* !UNIV_HOTBACKUP */
1856
1857/** mysql template structure defined in row0mysql.cc */
1858struct mysql_row_templ_t;
1859
1860/** Structure defines template related to virtual columns and
1861their base columns */
1863 /** number of regular columns */
1865
1866 /** number of virtual columns */
1868
1869 /** array of templates for virtual col and their base columns */
1871
1872 /** table's database name */
1873 std::string db_name;
1874
1875 /** table name */
1876 std::string tb_name;
1877
1878 /** share->table_name */
1879 std::string share_name;
1880
1881 /** MySQL record length */
1883
1884 /** default column value if any */
1886};
1887
1888/** The dirty status of tables, used to indicate if a table has some
1889dynamic metadata changed to be written back */
1891 /** Some persistent metadata is now dirty in memory, need to be
1892 written back to DDTableBuffer table and(or directly to) DD table.
1893 There could be some exceptions, when it's marked as dirty, but
1894 the metadata has already been written back to DDTableBuffer.
1895 For example, if a corrupted index is found and marked as corrupted,
1896 then it gets dropped. At this time, the dirty_status is still of
1897 this dirty value. Also a concurrent checkpoint make this bit
1898 out-of-date for other working threads, which still think the
1899 status is dirty and write-back is necessary.
1900 There could be either one row or no row for this table in
1901 DDTableBuffer table */
1903 /** Some persistent metadata is buffered in DDTableBuffer table,
1904 need to be written back to DD table. There is must be one row in
1905 DDTableBuffer table for this table */
1907 /** All persistent metadata are up to date. There is no row
1908 for this table in DDTableBuffer table */
1911
1912#ifndef UNIV_HOTBACKUP
1913/** A vector to collect prebuilt from different readers working on the same
1914temp table */
1915typedef std::vector<row_prebuilt_t *> temp_prebuilt_vec;
1916#endif /* !UNIV_HOTBACKUP */
1917
1918#ifdef UNIV_DEBUG
1919/** Value of 'magic_n'. */
1920constexpr uint32_t DICT_TABLE_MAGIC_N = 76333786;
1921#endif
1922
1923/** Data structure for a database table. Most fields will be
1924initialized to 0, NULL or false in dict_mem_table_create(). */
1926 /** Check if the table is compressed.
1927 @return true if compressed, false otherwise. */
1928 bool is_compressed() const { return (DICT_TF_GET_ZIP_SSIZE(flags) != 0); }
1929
1930 /** Check if the table is encrypted. Only for file per table tablespace.
1931 @return true if encrypted, false otherwise. */
1932 bool is_encrypted() const {
1934 }
1935
1936 /** Get reference count.
1937 @return current value of n_ref_count */
1938 inline uint64_t get_ref_count() const;
1939
1940 /** Acquire the table handle. */
1941 inline void acquire();
1942
1943 /** Acquire the table handle, with lock() and unlock() the table.
1944 This function needs to be called for opening table when the table
1945 is in memory and later the stats information would be initialized */
1946 inline void acquire_with_lock();
1947
1948 /** Release the table handle. */
1949 inline void release();
1950
1951 /** Lock the table handle. */
1952 inline void lock();
1953
1954 /** Unlock the table handle. */
1955 inline void unlock();
1956
1957#ifndef UNIV_HOTBACKUP
1958 /** Get schema and table name in system character set.
1959 @param[out] schema schema name
1960 @param[out] table table name */
1961 void get_table_name(std::string &schema, std::string &table) const;
1962
1963 bool is_system_schema() const {
1964 std::string schema_name;
1965 std::string table_name;
1966
1967 get_table_name(schema_name, table_name);
1968
1969 if (0 == strcmp(schema_name.c_str(), MYSQL_SCHEMA_NAME.str) ||
1970 0 == strcmp(schema_name.c_str(), "sys") ||
1971 0 == strcmp(schema_name.c_str(), PERFORMANCE_SCHEMA_DB_NAME.str) ||
1972 0 == strcmp(schema_name.c_str(), INFORMATION_SCHEMA_NAME.str)) {
1973 return (true);
1974 }
1975 return (false);
1976 }
1977
1978 /** Mutex of the table for concurrency access. */
1979 ib_mutex_t *mutex;
1980
1981 /** Creation state of mutex. */
1982 std::atomic<os_once::state_t> mutex_created;
1983#endif /* !UNIV_HOTBACKUP */
1984
1985 /** Id of the table. */
1987
1988 /** Memory heap. If you allocate from this heap after the table has
1989 been created then be sure to account the allocation into
1990 dict_sys->size. When closing the table we do something like
1991 dict_sys->size -= mem_heap_get_size(table->heap) and if that is going
1992 to become negative then we would assert. Something like this should do:
1993 old_size = mem_heap_get_size()
1994 mem_heap_alloc()
1995 new_size = mem_heap_get_size()
1996 dict_sys->size += new_size - old_size. */
1998
1999 /** Table name. */
2001
2002 /** Truncate name. */
2004
2005 /** NULL or the directory path specified by DATA DIRECTORY. */
2007
2008 /** NULL or the tablespace name that this table is assigned to,
2009 specified by the TABLESPACE option.*/
2011
2012 /** Space where the clustered index of the table is placed. */
2014
2015 /** dd::Tablespace::id of the table */
2017
2018 /** Stores information about:
2019 1 row format (redundant or compact),
2020 2 compressed page size (zip shift size),
2021 3 whether using atomic blobs,
2022 4 whether the table has been created with the option DATA DIRECTORY.
2023 Use DICT_TF_GET_COMPACT(), DICT_TF_GET_ZIP_SSIZE(),
2024 DICT_TF_HAS_ATOMIC_BLOBS() and DICT_TF_HAS_DATA_DIR() to parse this
2025 flag. */
2027
2028 /** Stores information about:
2029 1 whether the table has been created using CREATE TEMPORARY TABLE,
2030 2 whether the table has an internally defined DOC ID column,
2031 3 whether the table has a FTS index,
2032 4 whether DOC ID column need to be added to the FTS index,
2033 5 whether the table is being created its own tablespace,
2034 6 whether the table has been DISCARDed,
2035 7 whether the aux FTS tables names are in hex.
2036 8 whether the table is instinc table.
2037 9 whether the table has encryption setting.
2038 Use DICT_TF2_FLAG_IS_SET() to parse this flag. */
2040
2041 /** true if the table is an intermediate table during copy alter
2042 operation or a partition/subpartition which is required for copying
2043 data and skip the undo log for insertion of row in the table.
2044 This variable will be set and unset during extra(), or during the
2045 process of altering partitions */
2046 unsigned skip_alter_undo : 1;
2047
2048 /** true if this is in a single-table tablespace and the .ibd file is
2049 missing. Then we must return in ha_innodb.cc an error if the user
2050 tries to query such an orphaned table. */
2051 unsigned ibd_file_missing : 1;
2052
2053 /** true if the table object has been added to the dictionary cache. */
2054 unsigned cached : 1;
2055
2056 /** true if the table is to be dropped, but not yet actually dropped
2057 (could in the background drop list). It is turned on at the beginning
2058 of row_drop_table_for_mysql() and turned off just before we start to
2059 update system tables for the drop. It is protected by
2060 dict_operation_lock. */
2061 unsigned to_be_dropped : 1;
2062
2063 /** Number of non-virtual columns defined so far. */
2064 unsigned n_def : 10;
2065
2066 /** Number of non-virtual columns. */
2067 unsigned n_cols : 10;
2068
2069 /** Number of non-virtual columns before first instant ADD COLUMN,
2070 including the system columns like n_cols. This is used only when table has
2071 instant ADD clumns in V1. */
2072 unsigned n_instant_cols : 10;
2073
2074 /** Number of total columns (include virtual and non-virtual) */
2075 unsigned n_t_cols : 10;
2076
2077 /** Number of total columns defined so far. */
2078 unsigned n_t_def : 10;
2079
2080 /** Number of virtual columns defined so far. */
2081 unsigned n_v_def : 10;
2082
2083 /** Number of virtual columns. */
2084 unsigned n_v_cols : 10;
2085
2086 /** Number of multi-value virtual columns. */
2087 unsigned n_m_v_cols : 10;
2088
2089 /** true if this table is expected to be kept in memory. This table
2090 could be a table that has FK relationships or is undergoing DDL */
2092
2093 /** true if this table is not evictable(can_be_evicted) and this is
2094 because of DDL operation */
2095 unsigned ddl_not_evictable : 1;
2096
2097 /** true if some indexes should be dropped after ONLINE_INDEX_ABORTED
2098 or ONLINE_INDEX_ABORTED_DROPPED. */
2099 unsigned drop_aborted : 1;
2100
2101 /** Array of column descriptions. */
2103
2104 /** Array of virtual column descriptions. */
2106
2107 /** List of stored column descriptions. It is used only for foreign key
2108 check during create table and copy alter operations.
2109 During copy alter, s_cols list is filled during create table operation
2110 and need to preserve till rename table operation. That is the
2111 reason s_cols is a part of dict_table_t */
2113
2114 /** Check if the given column is a stored generated column. */
2116
2117 /** Column names packed in a character string
2118 "name1\0name2\0...nameN\0". Until the string contains n_cols, it will
2119 be allocated from a temporary heap. The final string will be allocated
2120 from table->heap. */
2121 const char *col_names;
2122
2123 /** Virtual column names */
2124 const char *v_col_names;
2125
2126 /** True if the table belongs to a system database (mysql, information_schema
2127 or performance_schema) */
2129
2130 /** Hash chain node. */
2132
2133 /** Hash chain node. */
2135
2136 /** The FTS_DOC_ID_INDEX, or NULL if no fulltext indexes exist */
2138
2139 /** List of indexes of the table. */
2141
2142 size_t get_index_count() const { return UT_LIST_GET_LEN(indexes); }
2143
2144 /** Node of the LRU list of tables. */
2146
2147 /** metadata version number of dd::Table::se_private_data() */
2148 uint64_t version;
2149
2150 /** Current row version in case columns are added/dropped INSTANTly */
2152
2153 /** Initial non-virtual column count */
2155
2156 /** Current non-virtual column count */
2158
2159 /** Total non-virtual column count */
2160 uint32_t total_col_count{0};
2161
2162 /** Set if table is upgraded instant table */
2164
2165 /** table dynamic metadata status, protected by dict_persist->mutex */
2166 std::atomic<table_dirty_status> dirty_status;
2167
2168#ifndef UNIV_HOTBACKUP
2169 /** Node of the dirty table list of tables, which is protected
2170 by dict_persist->mutex */
2171 UT_LIST_NODE_T(dict_table_t) dirty_dict_tables;
2172#endif /* !UNIV_HOTBACKUP */
2173
2174#ifdef UNIV_DEBUG
2175 /** This field is used to mark if a table is in the
2176 dirty_dict_tables_list. if the dirty_status is not of
2177 METADATA_CLEAN, the table should be in the list, otherwise not.
2178 This field should be protected by dict_persist->mutex too. */
2180#endif /* UNIV_DEBUG */
2181
2182 /** Count of how many foreign key check operations are currently being
2183 performed on the table. We cannot drop the table while there are
2184 foreign key checks running on it. */
2186
2187 /** Transaction id that last touched the table definition. Either when
2188 loading the definition or CREATE TABLE, or ALTER TABLE (prepare,
2189 commit, and rollback phases). */
2191
2192 /*!< set of foreign key constraints in the table; these refer to
2193 columns in other tables */
2195
2196 /*!< set of foreign key constraints which refer to this table */
2198
2199#ifdef UNIV_DEBUG
2200 /** This field is used to specify in simulations tables which are so
2201 big that disk should be accessed. Disk access is simulated by putting
2202 the thread to sleep for a while. NOTE that this flag is not stored to
2203 the data dictionary on disk, and the database will forget about value
2204 true if it has to reload the table definition from disk. */
2206#endif /* UNIV_DEBUG */
2207
2208 /** true if the maximum length of a single row exceeds BIG_ROW_SIZE.
2209 Initialized in dict_table_add_to_cache(). */
2210 unsigned big_rows : 1;
2211
2212#ifndef UNIV_HOTBACKUP
2213 /** Statistics for query optimization. @{ */
2214
2215 /** Creation state of 'stats_latch'. */
2216 std::atomic<os_once::state_t> stats_latch_created;
2217
2218 /** This latch protects:
2219 "dict_table_t::stat_initialized",
2220 "dict_table_t::stat_n_rows (*)",
2221 "dict_table_t::stat_clustered_index_size",
2222 "dict_table_t::stat_sum_of_other_index_sizes",
2223 "dict_table_t::stat_modified_counter (*)",
2224 "dict_table_t::indexes*::stats::n_diff_key_vals[]",
2225 "dict_table_t::indexes*::stats::index_size",
2226 "dict_table_t::indexes*::stats::n_leaf_pages".
2227 (*) Those are not always protected for
2228 performance reasons. */
2230
2231 /** Creation state of 'stats_compute_mutex'. */
2232 std::atomic<os_once::state_t> stats_compute_mutex_created;
2233
2234 /** Mutex protecting table and index statistics calculation process. */
2236
2237 /** true if statistics have been calculated the first time after
2238 database startup or table creation. */
2239 unsigned stat_initialized : 1;
2240
2241 /** true if statistics have been updated in the background and not yet
2242 collected by the optimizer */
2243 std::atomic<bool> stats_updated = false;
2244
2245 /** Timestamp of last recalc of the stats. */
2246 std::chrono::steady_clock::time_point stats_last_recalc;
2247
2248/** The two bits below are set in the 'stat_persistent' member. They
2249have the following meaning:
22501. _ON=0, _OFF=0, no explicit persistent stats setting for this table,
2251the value of the global srv_stats_persistent is used to determine
2252whether the table has persistent stats enabled or not
22532. _ON=0, _OFF=1, persistent stats are explicitly disabled for this
2254table, regardless of the value of the global srv_stats_persistent
22553. _ON=1, _OFF=0, persistent stats are explicitly enabled for this
2256table, regardless of the value of the global srv_stats_persistent
22574. _ON=1, _OFF=1, not allowed, we assert if this ever happens. */
2258#define DICT_STATS_PERSISTENT_ON (1 << 1)
2259#define DICT_STATS_PERSISTENT_OFF (1 << 2)
2260
2261 /** Indicates whether the table uses persistent stats or not. See
2262 DICT_STATS_PERSISTENT_ON and DICT_STATS_PERSISTENT_OFF. */
2264
2265/** The two bits below are set in the 'stats_auto_recalc' member. They
2266have the following meaning:
22671. _ON=0, _OFF=0, no explicit auto recalc setting for this table, the
2268value of the global srv_stats_persistent_auto_recalc is used to
2269determine whether the table has auto recalc enabled or not
22702. _ON=0, _OFF=1, auto recalc is explicitly disabled for this table,
2271regardless of the value of the global srv_stats_persistent_auto_recalc
22723. _ON=1, _OFF=0, auto recalc is explicitly enabled for this table,
2273regardless of the value of the global srv_stats_persistent_auto_recalc
22744. _ON=1, _OFF=1, not allowed, we assert if this ever happens. */
2275#define DICT_STATS_AUTO_RECALC_ON (1 << 1)
2276#define DICT_STATS_AUTO_RECALC_OFF (1 << 2)
2277
2278 /** Indicates whether the table uses automatic recalc for persistent
2279 stats or not. See DICT_STATS_AUTO_RECALC_ON and
2280 DICT_STATS_AUTO_RECALC_OFF. */
2282
2283 /** The number of pages to sample for this table during persistent
2284 stats estimation. If this is 0, then the value of the global
2285 srv_stats_persistent_sample_pages will be used instead. */
2287
2288 /** Approximate number of rows in the table. We periodically calculate
2289 new estimates. */
2290 uint64_t stat_n_rows;
2291
2292 /** Approximate clustered index size in database pages. */
2294
2295 /** Approximate size of other indexes in database pages. */
2297
2298 /** If FTS AUX table, parent table id */
2300
2301 /** How many rows are modified since last stats recalc. When a row is
2302 inserted, updated, or deleted, we add 1 to this number; we calculate
2303 new estimates for the table and the indexes if the table has changed
2304 too much, see row_update_statistics_if_needed(). The counter is reset
2305 to zero at statistics calculation. This counter is not protected by
2306 any latch, because this is only used for heuristics. */
2308
2309/** Background stats thread is not working on this table. */
2310#define BG_STAT_NONE 0
2311
2312/** Set in 'stats_bg_flag' when the background stats code is working
2313on this table. The DROP TABLE code waits for this to be cleared before
2314proceeding. */
2315#define BG_STAT_IN_PROGRESS (1 << 0)
2316
2317/** Set in 'stats_bg_flag' when DROP TABLE starts waiting on
2318BG_STAT_IN_PROGRESS to be cleared. The background stats thread will
2319detect this and will eventually quit sooner. */
2320#define BG_STAT_SHOULD_QUIT (1 << 1)
2321
2322 /** The state of the background stats thread wrt this table.
2323 See BG_STAT_NONE, BG_STAT_IN_PROGRESS and BG_STAT_SHOULD_QUIT.
2324 Writes are covered by dict_sys->mutex. It is read without mutex. */
2325 std::atomic<int8_t> stats_bg_flag;
2326
2327 /** @} */
2328#endif /* !UNIV_HOTBACKUP */
2329
2330 /** AUTOINC related members. @{ */
2331
2332 /* The actual collection of tables locked during AUTOINC read/write is
2333 kept in trx_t. In order to quickly determine whether a transaction has
2334 locked the AUTOINC lock we keep a pointer to the transaction here in
2335 the 'autoinc_trx' member. This is to avoid acquiring lock_sys latches and
2336 scanning the vector in trx_t.
2337 When an AUTOINC lock has to wait, the corresponding lock instance is
2338 created on the trx lock heap rather than use the pre-allocated instance
2339 in autoinc_lock below. */
2340
2341 /** A buffer for an AUTOINC lock for this table. We allocate the
2342 memory here so that individual transactions can get it and release it
2343 without a need to allocate space from the lock heap of the trx:
2344 otherwise the lock heap would grow rapidly if we do a large insert
2345 from a select. */
2346#ifndef UNIV_HOTBACKUP
2348
2349 /** Creation state of autoinc_mutex member */
2350 std::atomic<os_once::state_t> autoinc_mutex_created;
2351#endif /* !UNIV_HOTBACKUP */
2352
2353 /** Mutex protecting the autoincrement counter. */
2354 ib_mutex_t *autoinc_mutex;
2355
2356 /** Autoinc counter value to give to the next inserted row. */
2357 uint64_t autoinc;
2358
2359 /** Mutex protecting the persisted autoincrement counter. */
2361
2362 /** Autoinc counter value that has been persisted in redo logs or
2363 DDTableBuffer. It's mainly used when we want to write counter back
2364 to DDTableBuffer.
2365 This is different from the 'autoinc' above, which could be bigger
2366 than this one, because 'autoinc' will get updated right after
2367 some counters are allocated, but we will write the counter to redo
2368 logs and update this counter later. Once all allocated counters
2369 have been written to redo logs, 'autoinc' should be exact the next
2370 counter of this persisted one.
2371 We want this counter because when we need to write the counter back
2372 to DDTableBuffer, we had better keep it consistency with the counter
2373 that has been written to redo logs. Besides, we can't read the 'autoinc'
2374 directly easily, because the autoinc_lock is required and there could
2375 be a deadlock.
2376 This variable is protected by autoinc_persisted_mutex. */
2378
2379 /** The position of autoinc counter field in clustered index. This would
2380 be set when CREATE/ALTER/OPEN TABLE and IMPORT TABLESPACE, and used in
2381 modifications to clustered index, such as INSERT/UPDATE. There should
2382 be no conflict to access it, so no protection is needed. */
2384
2385 /** The transaction that currently holds the the AUTOINC lock on this table.
2386 Protected by lock_sys table shard latch. To "peek" the current value one
2387 can read it without any latch, understanding that in general it may change.
2388 Such access pattern is correct if trx thread wants to check if it has the lock
2389 granted, as the field can only change to other value when lock is released,
2390 which can not happen concurrently to thread executing the trx. */
2391 std::atomic<const trx_t *> autoinc_trx;
2392
2393 /** @} */
2394
2395#ifndef UNIV_HOTBACKUP
2396 /** FTS specific state variables. */
2398#endif /* !UNIV_HOTBACKUP */
2399
2400 /** Quiescing states, protected by the dict_index_t::lock. ie. we can
2401 only change the state if we acquire all the latches (dict_index_t::lock)
2402 in X mode of this table's indexes. */
2404
2405 /** Count of the number of record locks on this table. We use this to
2406 determine whether we can evict the table from the dictionary cache.
2407 Writes (atomic increments and decrements) are performed when holding a shared
2408 latch on lock_sys. (Note that this the table's shard latch is NOT required,
2409 as this is field counts *record* locks, so a page shard is latched instead)
2410 Reads should be performed when holding exclusive lock_sys latch, however:
2411 - Some places assert this field is zero without holding any latch.
2412 - Some places assert this field is positive holding only shared latch. */
2413 std::atomic<size_t> n_rec_locks;
2414
2415#ifndef UNIV_DEBUG
2416 private:
2417#endif
2418 /** Count of how many handles are opened to this table. Dropping of the
2419 table is NOT allowed until this count gets to zero. MySQL does NOT
2420 itself check the number of open handles at DROP. */
2421 std::atomic<uint64_t> n_ref_count;
2422
2423 public:
2424#ifndef UNIV_HOTBACKUP
2425 /** List of locks on the table. Protected by lock_sys shard latch. */
2427 /** count_by_mode[M] = number of locks in this->locks with
2428 lock->type_mode&LOCK_MODE_MASK == M.
2429 Used to quickly verify that there are no LOCK_S or LOCK_X, which are the only
2430 modes incompatible with LOCK_IS and LOCK_IX, to avoid costly iteration over
2431 this->locks when adding LOCK_IS or LOCK_IX.
2432 We use count_by_mode[LOCK_AUTO_INC] to track the number of granted and pending
2433 autoinc locks on this table. This value is set after acquiring the lock_sys
2434 table shard latch, but we peek the contents to determine whether other
2435 transactions have acquired the AUTOINC lock or not. Of course only one
2436 transaction can be granted the lock but there can be multiple
2437 waiters.
2438 Protected by lock_sys table shard latch. */
2440#endif /* !UNIV_HOTBACKUP */
2441
2442 /** Timestamp of the last modification of this table. */
2443 std::atomic<std::chrono::system_clock::time_point> update_time;
2444 static_assert(decltype(update_time)::is_always_lock_free);
2445
2446 /** row-id counter for use by intrinsic table for getting row-id.
2447 Given intrinsic table semantics, row-id can be locally maintained
2448 instead of getting it from central generator which involves mutex
2449 locking. */
2450 uint64_t sess_row_id;
2451
2452 /** trx_id counter for use by intrinsic table for getting trx-id.
2453 Intrinsic table are not shared so don't need a central trx-id
2454 but just need a increased counter to track consistent view while
2455 proceeding SELECT as part of UPDATE. */
2456 uint64_t sess_trx_id;
2457
2458#ifdef UNIV_DEBUG
2459 /** Magic number. */
2461#endif /* UNIV_DEBUG */
2462 /** mysql_row_templ_t for base columns used for compute the virtual
2463 columns */
2465
2466 /** remove the dict_table_t from cache after DDL operation */
2468
2469 /** refresh/reload FK info */
2471
2472#ifndef UNIV_HOTBACKUP
2473 /** multiple cursors can be active on this temporary table */
2475#endif /* !UNIV_HOTBACKUP */
2476
2477 /** true only for dictionary tables like mysql/tables,
2478 mysql/columns, mysql/tablespaces, etc. This flag is used
2479 to do non-locking reads on DD tables. */
2481
2482 /** true if this table is explicitly put to non-LRU list
2483 during table creation */
2485
2486 /** Check if the table has user defined primary key (PK).
2487 @return true if table has user defined PK, false otherwise. */
2488 bool has_pk() const;
2489
2490 /** @return the clustered index */
2491 const dict_index_t *first_index() const {
2493 const dict_index_t *first = UT_LIST_GET_FIRST(indexes);
2494 return (first);
2495 }
2496 /** @return the clustered index */
2498 return (const_cast<dict_index_t *>(
2499 const_cast<const dict_table_t *>(this)->first_index()));
2500 }
2501
2502 /** @returns true if the table has row versions.. */
2503 bool has_row_versions() const {
2504 if (current_row_version > 0) {
2506 return (true);
2507 }
2508
2509 return false;
2510 }
2511
2512 /** @return if there was any instantly added column.
2513 This will be true after one or more instant ADD COLUMN, however,
2514 it would become false after ALTER TABLE which rebuilds or copies
2515 the old table.
2516 If this is true, all instantly added columns should have default
2517 values, and records in the table may have REC_INFO_INSTANT_FLAG set. */
2518 bool has_instant_cols() const {
2520 /* Instant add col V1 */
2521 return (true);
2522 }
2523
2524 return false;
2525 }
2526
2527 /** Set the number of columns when the first instant ADD COLUMN happens.
2528 @param[in] n_inst_cols number of fields when first instant
2529 ADD COLUMN happens, without system columns */
2530 void set_instant_cols(uint16_t n_inst_cols) {
2531 n_instant_cols = static_cast<unsigned>(n_inst_cols) + get_n_sys_cols();
2532 }
2533
2534 /** Get the number of user columns when the first instant ADD COLUMN
2535 happens.
2536 @return the number of user columns as described above */
2537 uint16_t get_instant_cols() const {
2538 return static_cast<uint16_t>(n_instant_cols - get_n_sys_cols());
2539 }
2540
2542 size_t n_cols_dropped = get_n_instant_drop_cols();
2543 size_t n_cols_added = get_n_instant_add_cols();
2544 size_t n_instant_added_cols =
2545 n_cols + n_cols_dropped - n_cols_added - n_instant_cols;
2546
2547 return (n_instant_added_cols);
2548 }
2549
2550 /** Get number of columns added instantly */
2551 uint32_t get_n_instant_add_cols() const {
2554 }
2555
2556 /** Get number of columns dropped instantly */
2557 uint32_t get_n_instant_drop_cols() const {
2560 }
2561
2562 /** check if table has INSTANT ADD columns.
2563 @return true if the table has INSTANT ADD columns, otherwise false */
2564 bool has_instant_add_cols() const { return (get_n_instant_add_cols() > 0); }
2565
2566 /** check if table has INSTANT DROP columns.
2567 @return true if the table has INSTANT DROP columns, otherwise false */
2568 bool has_instant_drop_cols() const { return (get_n_instant_drop_cols() > 0); }
2569
2570 /** Set table to be upgraded table with INSTANT ADD columns in V1. */
2572
2573 /** Checks if table is upgraded table with INSTANT ADD columns in V1.
2574 @return true if it is, false otherwise */
2576
2577 /** Check whether the table is corrupted.
2578 @return true if the table is corrupted, otherwise false */
2579 bool is_corrupted() const {
2581
2582 const dict_index_t *index = first_index();
2583
2584 /* It is possible that this table is only half created, in which case
2585 the clustered index may be NULL. If the clustered index is corrupted,
2586 the table is corrupt. We do not consider the table corrupt if only
2587 a secondary index is corrupt. */
2588 ut_ad(index == nullptr || index->is_clustered());
2589
2590 return (index != nullptr && index->type & DICT_CORRUPT);
2591 }
2592
2593 /** Returns a column's name.
2594 @param[in] col_nr column number
2595 @return column name. NOTE: not guaranteed to stay valid if table is
2596 modified in any way (columns added, etc.). */
2597 const char *get_col_name(ulint col_nr) const {
2598 ut_ad(col_nr < n_def);
2600
2601 const char *s = col_names;
2602 if (s) {
2603 for (ulint i = 0; i < col_nr; i++) {
2604 s += strlen(s) + 1;
2605 }
2606 }
2607
2608 return (s);
2609 }
2610
2611 /** Gets the nth column of a table.
2612 @param[in] pos position of column
2613 @return pointer to column object */
2614 dict_col_t *get_col(uint pos) const {
2615 ut_ad(pos < n_def);
2617
2618 return (cols + pos);
2619 }
2620
2621 /** Get column by name
2622 @param[in] name column name
2623 @return column name if found, null otherwise */
2624 dict_col_t *get_col_by_name(const char *name) const {
2625 ut_ad(name != nullptr);
2626
2627 dict_col_t *ret = nullptr;
2628
2629 const char *s = col_names;
2630 for (ulint i = 0; i < n_def; i++) {
2631 if (strcmp(s, name) == 0) {
2632 ret = get_col(i);
2633 }
2634 s += strlen(s) + 1;
2635 }
2636
2637 return ret;
2638 }
2639
2640 /** Gets the number of user-defined non-virtual columns in a table
2641 in the dictionary cache.
2642 @return number of user-defined (e.g., not ROW_ID) non-virtual columns
2643 of a table */
2644 uint16_t get_n_user_cols() const {
2646
2647 return (static_cast<uint16_t>(n_cols) - get_n_sys_cols());
2648 }
2649
2650 /** Gets the number of system columns in a table.
2651 For intrinsic table on ROW_ID column is added for all other
2652 tables TRX_ID and ROLL_PTR are all also appended.
2653 @return number of system (e.g., ROW_ID) columns of a table */
2654 uint16_t get_n_sys_cols() const {
2656
2658 }
2659
2660 /** Gets the number of all non-virtual columns (also system) in a table
2661 in the dictionary cache.
2662 @return number of non-virtual columns of a table */
2665
2666 return (n_cols);
2667 }
2668
2669 /** Gets the number of all non-virtual columns in a table including columns
2670 dropped INSTANTly.
2671 @returns number of non-virtual columns of a table */
2673 if (!has_row_versions()) {
2674 return n_cols;
2675 }
2676
2680 }
2681
2682 /** Gets the given system column of a table.
2683 @param[in] sys DATA_ROW_ID, ...
2684 @return pointer to column object */
2686 dict_col_t *col;
2687
2688 ut_ad(sys < get_n_sys_cols());
2690
2691 col = get_col(n_cols - get_n_sys_cols() + sys);
2692 ut_ad(col->mtype == DATA_SYS);
2693 ut_ad(col->prtype == (sys | DATA_NOT_NULL));
2694
2695 return (col);
2696 }
2697
2698 /** Determine if this is a temporary table. */
2699 bool is_temporary() const {
2701 return (flags2 & DICT_TF2_TEMPORARY);
2702 }
2703
2704 /** Determine if this is a FTS AUX table. */
2705 bool is_fts_aux() const {
2707 return (flags2 & DICT_TF2_AUX);
2708 }
2709
2710 /** Determine whether the table is intrinsic.
2711 An intrinsic table is a special kind of temporary table that
2712 is invisible to the end user. It can be created internally by InnoDB,
2713 the MySQL server layer or other modules connected to InnoDB in order
2714 to gather and use data as part of a larger task. Since access to it
2715 must be as fast as possible, it does not need UNDO semantics, system
2716 fields DB_TRX_ID & DB_ROLL_PTR, doublewrite, checksum, insert buffer,
2717 use of the shared data dictionary, locking, or even a transaction.
2718 In short, these are not ACID tables at all, just temporary data stored
2719 and manipulated during a larger process.*/
2720 bool is_intrinsic() const {
2721 if (flags2 & DICT_TF2_INTRINSIC) {
2723 return (true);
2724 }
2725
2726 return (false);
2727 }
2728
2729 /* GAP locks are skipped for DD tables and SDI tables
2730 @return true if table is DD table or SDI table, else false */
2731 inline bool skip_gap_locks() const;
2732
2733 /** Determine if the table can support instant ADD/DROP COLUMN */
2734 inline bool support_instant_add_drop() const;
2735};
2736
2738 if (s_cols != nullptr) {
2739 for (auto &stored_gcol : *s_cols) {
2740 if (stored_gcol.m_col == col) {
2741 return &stored_gcol;
2742 }
2743 }
2744 }
2745 return nullptr;
2746}
2747
2748static inline void DICT_TF2_FLAG_SET(dict_table_t *table, uint32_t flag) {
2749 table->flags2 |= flag;
2750}
2751
2752static inline bool DICT_TF2_FLAG_IS_SET(const dict_table_t *table,
2753 uint32_t flag) {
2754 return table->flags2 & flag;
2755}
2756
2757static inline void DICT_TF2_FLAG_UNSET(dict_table_t *table, uint32_t flag) {
2758 table->flags2 &= ~flag;
2759}
2760
2762
2763/** Persistent dynamic metadata type, there should be 1 to 1
2764relationship between the metadata and the type. Please keep them in order
2765so that we can iterate over it */
2767 /** The smallest type, which should be 1 less than the first
2768 true type */
2770
2771 /** Persistent Metadata type for corrupted indexes */
2773
2774 /** Persistent Metadata type for autoinc counter */
2776
2777 /* TODO: Will add following types
2778 PM_TABLE_UPDATE_TIME = 3,
2779 Maybe something tablespace related
2780 PM_TABLESPACE_SIZE = 4,
2781 PM_TABLESPACE_MAX_TRX_ID = 5, */
2782
2783 /** The biggest type, which should be 1 bigger than the last
2784 true type */
2785 PM_BIGGEST_TYPE = 3
2787
2788typedef std::vector<index_id_t, ut::allocator<index_id_t>> corrupted_ids_t;
2789
2790/** Persistent dynamic metadata for a table */
2792 public:
2793 /** Constructor
2794 @param[in] id table id
2795 @param[in] version table dynamic metadata version */
2798
2799 /** Get the corrupted indexes' IDs
2800 @return the vector of indexes' IDs */
2802 return (m_corrupted_ids);
2803 }
2804
2805 /** Add a corrupted index id and space id
2806 @param[in] id corrupted index id */
2808 m_corrupted_ids.push_back(id);
2809 }
2810
2811 /** Set the dynamic metadata version.
2812 @param[in] version dynamic metadata version */
2813 void set_version(uint64_t version) { m_version = version; }
2814
2815 /** Get the dynamic metadata version */
2816 uint64_t get_version() const { return (m_version); }
2817
2818 /** Get the table id of the metadata
2819 @return table id */
2820 table_id_t get_table_id() const { return (m_id); }
2821
2822 /** Set the autoinc counter of the table if it's bigger
2823 @param[in] autoinc autoinc counter */
2824 void set_autoinc_if_bigger(uint64_t autoinc) {
2825 /* We only set the biggest autoinc counter. Callers don't
2826 guarantee passing a bigger number in. */
2827 if (autoinc > m_autoinc) {
2828 m_autoinc = autoinc;
2829 }
2830 }
2831
2832 /** Set the autoinc counter of the table
2833 @param[in] autoinc autoinc counter */
2834 void set_autoinc(uint64_t autoinc) { m_autoinc = autoinc; }
2835
2836 /** Get the autoinc counter of the table
2837 @return the autoinc counter */
2838 uint64_t get_autoinc() const { return (m_autoinc); }
2839
2840 private:
2841 /** Table ID which this metadata belongs to */
2843
2844 /** Table dynamic metadata version of the change */
2845 uint64_t m_version;
2846
2847 /** Storing the corrupted indexes' ID if exist, or else empty */
2849
2850 /** Autoinc counter of the table */
2851 uint64_t m_autoinc;
2852
2853 /* TODO: We will add update_time, etc. here and APIs accordingly */
2854};
2855
2856/** Interface for persistent dynamic table metadata. */
2858 public:
2859 /** Virtual destructor */
2860 virtual ~Persister() = default;
2861
2862 /** Write the dynamic metadata of a table, we can pre-calculate
2863 the size by calling get_write_size()
2864 @param[in] metadata persistent data
2865 @param[out] buffer write buffer
2866 @param[in] size size of write buffer, should be
2867 at least get_write_size()
2868 @return the length of bytes written */
2869 virtual ulint write(const PersistentTableMetadata &metadata, byte *buffer,
2870 ulint size) const = 0;
2871
2872 /** Pre-calculate the size of metadata to be written
2873 @param[in] metadata metadata to be written
2874 @return the size of metadata */
2876 const PersistentTableMetadata &metadata) const = 0;
2877
2878 /** Read the dynamic metadata from buffer, and store them to
2879 metadata object
2880 @param[out] metadata metadata where we store the read data
2881 @param[in] buffer buffer to read
2882 @param[in] size size of buffer
2883 @param[out] corrupt true if we found something wrong in
2884 the buffer except incomplete buffer,
2885 otherwise false
2886 @return the bytes we read from the buffer if the buffer data
2887 is complete and we get everything, 0 if the buffer is incompleted */
2888 virtual ulint read(PersistentTableMetadata &metadata, const byte *buffer,
2889 ulint size, bool *corrupt) const = 0;
2890
2891 /** Aggregate metadata entries into a single metadata instance, considering
2892 version numbers
2893 @param[in,out] metadata metadata object to be modified
2894 @param[in] new_entry metadata entry from logs */
2895 virtual void aggregate(PersistentTableMetadata &metadata,
2896 const PersistentTableMetadata &new_entry) const = 0;
2897
2898 /** Write MLOG_TABLE_DYNAMIC_META for persistent dynamic
2899 metadata of table
2900 @param[in] id Table id
2901 @param[in] metadata Metadata used to write the log
2902 @param[in,out] mtr Mini-transaction */
2903 void write_log(table_id_t id, const PersistentTableMetadata &metadata,
2904 mtr_t *mtr) const;
2905};
2906
2907/** Persister used for corrupted indexes */
2909 public:
2910 /** Write the corrupted indexes of a table, we can pre-calculate the size
2911 by calling get_write_size()
2912 @param[in] metadata persistent data
2913 @param[out] buffer write buffer
2914 @param[in] size size of write buffer, should be at least
2915 get_write_size()
2916 @return the length of bytes written */
2917 ulint write(const PersistentTableMetadata &metadata, byte *buffer,
2918 ulint size) const override;
2919
2920 /** Pre-calculate the size of metadata to be written
2921 @param[in] metadata metadata to be written
2922 @return the size of metadata */
2923 ulint get_write_size(const PersistentTableMetadata &metadata) const override;
2924
2925 /** Read the corrupted indexes from buffer, and store them to
2926 metadata object
2927 @param[out] metadata metadata where we store the read data
2928 @param[in] buffer buffer to read
2929 @param[in] size size of buffer
2930 @param[out] corrupt true if we found something wrong in
2931 the buffer except incomplete buffer,
2932 otherwise false
2933 @return the bytes we read from the buffer if the buffer data
2934 is complete and we get everything, 0 if the buffer is incompleted */
2935 ulint read(PersistentTableMetadata &metadata, const byte *buffer, ulint size,
2936 bool *corrupt) const override;
2937
2938 void aggregate(PersistentTableMetadata &metadata,
2939 const PersistentTableMetadata &new_entry) const override;
2940
2941 private:
2942 /** The length of index_id_t we will write */
2943 static const size_t INDEX_ID_LENGTH = 12;
2944};
2945
2946/** Persister used for autoinc counters */
2948 public:
2949 /** Write the autoinc counter of a table, we can pre-calculate
2950 the size by calling get_write_size()
2951 @param[in] metadata persistent metadata
2952 @param[out] buffer write buffer
2953 @param[in] size size of write buffer, should be
2954 at least get_write_size()
2955 @return the length of bytes written */
2956 ulint write(const PersistentTableMetadata &metadata, byte *buffer,
2957 ulint size) const override;
2958
2959 /** Pre-calculate the size of metadata to be written
2960 @param[in] metadata metadata to be written
2961 @return the size of metadata */
2963 [[maybe_unused]]) const override {
2964 /* We just return the max possible size that would be used
2965 if the counter exists, so we don't calculate every time.
2966 Here we need 1 byte for dynamic metadata type and 11 bytes
2967 for the max possible size of counter. */
2968 return (12);
2969 }
2970
2971 /** Read the autoinc counter from buffer, and store them to
2972 metadata object
2973 @param[out] metadata metadata where we store the read data
2974 @param[in] buffer buffer to read
2975 @param[in] size size of buffer
2976 @param[out] corrupt true if we found something wrong in
2977 the buffer except incomplete buffer,
2978 otherwise false
2979 @return the bytes we read from the buffer if the buffer data
2980 is complete and we get everything, 0 if the buffer is incomplete */
2981 ulint read(PersistentTableMetadata &metadata, const byte *buffer, ulint size,
2982 bool *corrupt) const override;
2983
2984 void aggregate(PersistentTableMetadata &metadata,
2985 const PersistentTableMetadata &new_entry) const override;
2986};
2987
2988/** Container of persisters used in the system. Currently we don't need
2989to protect this object since we only initialize it at very beginning and
2990destroy it in the end. During the server running, we only get the persisters */
2992 typedef std::map<
2993 persistent_type_t, Persister *, std::less<persistent_type_t>,
2996
2997 public:
2998 /** Constructor */
3000
3001 /** Destructor */
3002 ~Persisters();
3003
3004 /** Get the persister object with specified type
3005 @param[in] type persister type
3006 @return Persister object required or NULL if not found */
3008
3009 /** Add a specified persister of type, we will allocate the Persister
3010 if there is no such persister exist, otherwise do nothing and return
3011 the existing one
3012 @param[in] type persister type
3013 @return the persister of type */
3015
3016 /** Remove a specified persister of type, we will free the Persister
3017 @param[in] type persister type */
3019
3020 /** Serialize the metadata to a buffer
3021 @param[in] metadata metadata to serialize
3022 @param[out] buffer buffer to store the serialized metadata
3023 @return the length of serialized metadata */
3024 size_t write(PersistentTableMetadata &metadata, byte *buffer);
3025
3026 private:
3027 /** A map to store all persisters needed */
3029};
3030
3031#ifndef UNIV_HOTBACKUP
3032
3033/** A function object to add the foreign key constraint to the referenced set
3034of the referenced table, if it exists in the dictionary cache. */
3036 void operator()(dict_foreign_t *foreign) const {
3037 if (dict_table_t *table = foreign->referenced_table) {
3038 std::pair<dict_foreign_set::iterator, bool> ret =
3039 table->referenced_set.insert(foreign);
3040 ut_a(ret.second);
3041 }
3042 }
3043};
3044
3045/** Request for lazy creation of the mutex of a given table.
3046This function is only called from either single threaded environment
3047or from a thread that has not shared the table object with other threads.
3048@param[in,out] table table whose mutex is to be created */
3050 table->mutex = nullptr;
3051 table->mutex_created = os_once::NEVER_DONE;
3052}
3053
3054/** Destroy the mutex of a given table.
3055This function is only called from either single threaded environment
3056or from a thread that has not shared the table object with other threads.
3057@param[in,out] table table whose mutex is to be created */
3059 if (table->mutex_created == os_once::DONE) {
3060 if (table->mutex != nullptr) {
3061 mutex_free(table->mutex);
3062 ut::delete_(table->mutex);
3063 }
3064 }
3065}
3066
3067/** Destroy the autoinc latch of the given table.
3068This function is only called from either single threaded environment
3069or from a thread that has not shared the table object with other threads.
3070@param[in,out] table table whose stats latch to destroy */
3072 if (table->autoinc_mutex_created == os_once::DONE) {
3073 if (table->autoinc_mutex != nullptr) {
3074 mutex_free(table->autoinc_mutex);
3075 ut::delete_(table->autoinc_mutex);
3076 }
3077
3078 if (table->autoinc_persisted_mutex != nullptr) {
3079 mutex_free(table->autoinc_persisted_mutex);
3080 ut::delete_(table->autoinc_persisted_mutex);
3081 }
3082 }
3083}
3084
3085/** Request for lazy creation of the autoinc latch of a given table.
3086This function is only called from either single threaded environment
3087or from a thread that has not shared the table object with other threads.
3088@param[in,out] table table whose autoinc latch is to be created. */
3090 table->autoinc_mutex = nullptr;
3091 table->autoinc_persisted_mutex = nullptr;
3092 table->autoinc_mutex_created = os_once::NEVER_DONE;
3093}
3094
3095/** Request a lazy creation of dict_index_t::zip_pad::mutex.
3096This function is only called from either single threaded environment
3097or from a thread that has not shared the table object with other threads.
3098@param[in,out] index index whose zip_pad mutex is to be created */
3100 index->zip_pad.mutex = nullptr;
3101 index->zip_pad.mutex_created = os_once::NEVER_DONE;
3102}
3103
3104/** Destroy the zip_pad_mutex of the given index.
3105This function is only called from either single threaded environment
3106or from a thread that has not shared the table object with other threads.
3107@param[in,out] index index whose stats latch to destroy */
3109 if (index->zip_pad.mutex_created == os_once::DONE &&
3110 index->zip_pad.mutex != nullptr) {
3111 mutex_free(index->zip_pad.mutex);
3112 ut::delete_(index->zip_pad.mutex);
3113 }
3114}
3115#endif /* !UNIV_HOTBACKUP */
3116
3117/** Release the zip_pad_mutex of a given index.
3118@param[in,out] index index whose zip_pad_mutex is to be released */
3120#ifndef UNIV_HOTBACKUP
3121 mutex_exit(index->zip_pad.mutex);
3122#endif /* !UNIV_HOTBACKUP */
3123}
3124
3125#ifdef UNIV_DEBUG
3126/** Check if the current thread owns the autoinc_mutex of a given table.
3127@param[in] table the autoinc_mutex belongs to this table
3128@return true, if the current thread owns the autoinc_mutex, false otherwise.*/
3130 return (mutex_own(table->autoinc_mutex));
3131}
3132#endif /* UNIV_DEBUG */
3133
3134#ifndef UNIV_HOTBACKUP
3135/** Data structure storing index statistics. Used as
3136temporary state during statistics calculation. The final version of statistics
3137for reading by optimizer are stored in dict_index_t::stats. */
3140 unsigned type : DICT_IT_BITS;
3141 unsigned n_uniq : 10;
3142};
3143#endif /* !UNIV_HOTBACKUP */
3144
3145#include "dict0mem.ic"
3146
3147#endif /* dict0mem_h */
uint32_t space_id_t
Tablespace identifier.
Definition: api0api.h:49
Kerberos Client Authentication nullptr
Definition: auth_kerberos_client_plugin.cc:247
The index tree general types.
The database buffer pool high-level routines.
Persister used for autoinc counters.
Definition: dict0mem.h:2947
ulint write(const PersistentTableMetadata &metadata, byte *buffer, ulint size) const override
Write the autoinc counter of a table, we can pre-calculate the size by calling get_write_size()
Definition: dict0dict.cc:5621
ulint read(PersistentTableMetadata &metadata, const byte *buffer, ulint size, bool *corrupt) const override
Read the autoinc counter from buffer, and store them to metadata object.
Definition: dict0dict.cc:5648
void aggregate(PersistentTableMetadata &metadata, const PersistentTableMetadata &new_entry) const override
Aggregate metadata entries into a single metadata instance, considering version numbers.
Definition: dict0dict.cc:5668
ulint get_write_size(const PersistentTableMetadata &metadata) const override
Pre-calculate the size of metadata to be written.
Definition: dict0mem.h:2962
Persister used for corrupted indexes.
Definition: dict0mem.h:2908
ulint get_write_size(const PersistentTableMetadata &metadata) const override
Pre-calculate the size of metadata to be written.
Definition: dict0dict.cc:5539
static const size_t INDEX_ID_LENGTH
The length of index_id_t we will write.
Definition: dict0mem.h:2943
ulint read(PersistentTableMetadata &metadata, const byte *buffer, ulint size, bool *corrupt) const override
Read the corrupted indexes from buffer, and store them to metadata object.
Definition: dict0dict.cc:5567
ulint write(const PersistentTableMetadata &metadata, byte *buffer, ulint size) const override
Write the corrupted indexes of a table, we can pre-calculate the size by calling get_write_size()
Definition: dict0dict.cc:5503
void aggregate(PersistentTableMetadata &metadata, const PersistentTableMetadata &new_entry) const override
Aggregate metadata entries into a single metadata instance, considering version numbers.
Definition: dict0dict.cc:5606
Persistent dynamic metadata for a table.
Definition: dict0mem.h:2791
uint64_t get_autoinc() const
Get the autoinc counter of the table.
Definition: dict0mem.h:2838
table_id_t get_table_id() const
Get the table id of the metadata.
Definition: dict0mem.h:2820
void add_corrupted_index(const index_id_t id)
Add a corrupted index id and space id.
Definition: dict0mem.h:2807
const corrupted_ids_t & get_corrupted_indexes() const
Get the corrupted indexes' IDs.
Definition: dict0mem.h:2801
void set_version(uint64_t version)
Set the dynamic metadata version.
Definition: dict0mem.h:2813
void set_autoinc(uint64_t autoinc)
Set the autoinc counter of the table.
Definition: dict0mem.h:2834
uint64_t m_autoinc
Autoinc counter of the table.
Definition: dict0mem.h:2851
void set_autoinc_if_bigger(uint64_t autoinc)
Set the autoinc counter of the table if it's bigger.
Definition: dict0mem.h:2824
table_id_t m_id
Table ID which this metadata belongs to.
Definition: dict0mem.h:2842
uint64_t get_version() const
Get the dynamic metadata version.
Definition: dict0mem.h:2816
uint64_t m_version
Table dynamic metadata version of the change.
Definition: dict0mem.h:2845
corrupted_ids_t m_corrupted_ids
Storing the corrupted indexes' ID if exist, or else empty.
Definition: dict0mem.h:2848
PersistentTableMetadata(table_id_t id, uint64_t version)
Constructor.
Definition: dict0mem.h:2796
Interface for persistent dynamic table metadata.
Definition: dict0mem.h:2857
virtual ~Persister()=default
Virtual destructor.
void write_log(table_id_t id, const PersistentTableMetadata &metadata, mtr_t *mtr) const
Write MLOG_TABLE_DYNAMIC_META for persistent dynamic metadata of table.
Definition: dict0dict.cc:5468
virtual ulint write(const PersistentTableMetadata &metadata, byte *buffer, ulint size) const =0
Write the dynamic metadata of a table, we can pre-calculate the size by calling get_write_size()
virtual ulint read(PersistentTableMetadata &metadata, const byte *buffer, ulint size, bool *corrupt) const =0
Read the dynamic metadata from buffer, and store them to metadata object.
virtual ulint get_write_size(const PersistentTableMetadata &metadata) const =0
Pre-calculate the size of metadata to be written.
virtual void aggregate(PersistentTableMetadata &metadata, const PersistentTableMetadata &new_entry) const =0
Aggregate metadata entries into a single metadata instance, considering version numbers.
Container of persisters used in the system.
Definition: dict0mem.h:2991
persisters_t m_persisters
A map to store all persisters needed.
Definition: dict0mem.h:3028
std::map< persistent_type_t, Persister *, std::less< persistent_type_t >, ut::allocator< std::pair< const persistent_type_t, Persister * > > > persisters_t
Definition: dict0mem.h:2995
~Persisters()
Destructor.
Definition: dict0dict.cc:5680
void remove(persistent_type_t type)
Remove a specified persister of type, we will free the Persister.
Definition: dict0dict.cc:5734
size_t write(PersistentTableMetadata &metadata, byte *buffer)
Serialize the metadata to a buffer.
Definition: dict0dict.cc:5748
Persister * get(persistent_type_t type) const
Get the persister object with specified type.
Definition: dict0dict.cc:5690
Persisters()
Constructor.
Definition: dict0mem.h:2999
Persister * add(persistent_type_t type)
Add a specified persister of type, we will allocate the Persister if there is no such persister exist...
Definition: dict0dict.cc:5704
The state of the FTS sub system.
Definition: fts0fts.h:364
SQL identifier name wrapper for pretty-printing.
Definition: dict0mem.h:437
const char * operator()() const
Explicit type conversion.
Definition: dict0mem.h:458
id_name_t & operator=(const char *name)
Assignment operator.
Definition: dict0mem.h:447
const char * m_name
The name in internal representation.
Definition: dict0mem.h:462
id_name_t(const char *name)
Constructor.
Definition: dict0mem.h:443
id_name_t()
Default constructor.
Definition: dict0mem.h:440
Globally unique index identifier.
Definition: dict0types.h:226
Cache position of last inserted or selected record by caching record and holding reference to the blo...
Definition: dict0mem.h:988
last_ops_cur_t()
Constructor.
Definition: dict0mem.h:991
void release()
Definition: dict0mem.h:996
bool disable_caching
disable caching.
Definition: dict0mem.h:1016
mtr_t mtr
active mtr that will be re-used for next insert/select.
Definition: dict0mem.h:1013
buf_block_t * block
block where record reside.
Definition: dict0mem.h:1010
rec_t * rec
last inserted/selected record.
Definition: dict0mem.h:1007
bool invalid
If index structure is undergoing structural change viz.
Definition: dict0mem.h:1021
static const state_t NEVER_DONE
Not yet executed.
Definition: os0once.h:70
static const state_t DONE
Finished execution.
Definition: os0once.h:76
Page size descriptor.
Definition: page0size.h:50
Allocator that allows std::* containers to manage their memory through ut::malloc* and ut::free libra...
Definition: ut0new.h:2183
#define PERFORMANCE_SCHEMA_DB_NAME
Name of the performance schema database.
Definition: client_priv.h:219
Data types.
constexpr uint32_t DATA_MULTI_VALUE
Multi-value Virtual column.
Definition: data0type.h:225
ulint DATA_MBMINMAXLEN(ulint mbminlen, ulint mbmaxlen)
Definition: data0type.h:250
constexpr uint32_t DATA_MBMAX
Definition: data0type.h:238
static ulint dtype_get_max_size_low(ulint mtype, ulint len)
Returns the maximum size of a data type.
constexpr uint32_t DATA_VIRTUAL
Virtual column.
Definition: data0type.h:223
constexpr uint32_t DATA_ITT_N_SYS_COLS
number of system columns for intrinsic temporary table
Definition: data0type.h:197
constexpr uint32_t DATA_SYS
system column
Definition: data0type.h:75
ulint DATA_MBMINLEN(ulint mbminmaxlen)
Definition: data0type.h:255
ulint DATA_MBMAXLEN(ulint mbminmaxlen)
Definition: data0type.h:259
static ulint dtype_get_fixed_size_low(ulint mtype, ulint prtype, ulint len, ulint mbminmaxlen, bool comp)
Returns the size of a fixed size data type, 0 if not a fixed size type.
constexpr uint32_t DATA_NOT_NULL
this is ORed to the precise type when the column is declared as NOT NULL
Definition: data0type.h:207
constexpr uint32_t DATA_N_SYS_COLS
number of system columns defined above
Definition: data0type.h:194
static ulint dtype_get_min_size_low(ulint mtype, ulint prtype, ulint len, ulint mbminmaxlen)
Returns the minimum size of a data type.
bool DATA_GEOMETRY_MTYPE(ulint mtype)
Definition: data0type.h:269
void dict_mem_init(void)
Initialize dict memory variables.
Definition: dict0mem.cc:834
constexpr uint32_t DICT_CLUSTERED
Type flags of an index: OR'ing of the flags is allowed to define a combination of types.
Definition: dict0mem.h:97
void dict_table_autoinc_create_lazy(dict_table_t *table)
Request for lazy creation of the autoinc latch of a given table.
Definition: dict0mem.h:3089
char * dict_mem_create_temporary_tablename(mem_heap_t *heap, const char *dbtab, table_id_t id)
Create a temporary tablename like "#sql-ibtid-inc" where tid = the Table ID inc = a randomly initiali...
Definition: dict0mem.cc:812
void dict_mem_foreign_fill_vcol_set(dict_foreign_t *foreign)
Fills the dependent virtual columns in a set.
Definition: dict0mem.cc:498
static void DICT_TF2_FLAG_UNSET(dict_table_t *table, uint32_t flag)
Definition: dict0mem.h:2757
void dict_mem_foreign_table_name_lookup_set(dict_foreign_t *foreign, bool do_alloc)
Sets the foreign_table_name_lookup pointer based on the value of lower_case_table_names.
Definition: dict0mem.cc:365
constexpr uint32_t DICT_TF2_FTS_ADD_DOC_ID
Need to add Doc ID column for FTS index build.
Definition: dict0mem.h:280
constexpr uint32_t DICT_TF2_ENCRYPTION_FILE_PER_TABLE
Encryption table bit for innodb_file-per-table only.
Definition: dict0mem.h:296
constexpr uint32_t DICT_TF_BIT_MASK
A mask of all the known/used bits in table flags.
Definition: dict0mem.h:194
constexpr uint32_t DICT_IT_BITS
number of bits used for SYS_INDEXES.TYPE
Definition: dict0mem.h:116
void dict_index_zip_pad_mutex_destroy(dict_index_t *index)
Destroy the zip_pad_mutex of the given index.
Definition: dict0mem.h:3108
ulong zip_failure_threshold_pct
Percentage of compression failures that are allowed in a single round.
Definition: dict0dict.cc:179
constexpr uint32_t DICT_TF_WIDTH_SHARED_SPACE
Width of the SHARED tablespace flag.
Definition: dict0mem.h:185
std::set< dict_foreign_t *, dict_foreign_compare, ut::allocator< dict_foreign_t * > > dict_foreign_set
Definition: dict0mem.h:1763
table_dirty_status
The dirty status of tables, used to indicate if a table has some dynamic metadata changed to be writt...
Definition: dict0mem.h:1890
@ METADATA_CLEAN
All persistent metadata are up to date.
Definition: dict0mem.h:1909
@ METADATA_BUFFERED
Some persistent metadata is buffered in DDTableBuffer table, need to be written back to DD table.
Definition: dict0mem.h:1906
@ METADATA_DIRTY
Some persistent metadata is now dirty in memory, need to be written back to DDTableBuffer table and(o...
Definition: dict0mem.h:1902
constexpr uint32_t MAX_KEY_LENGTH_BITS
Definition: dict0mem.h:1063
constexpr char INSTANT_DROP_SUFFIX_8_0_29[]
Format of INSTANTLY DROPPED column names.
Definition: dict0mem.h:86
constexpr uint32_t DICT_N_COLS_COMPACT
This bitmask is used in SYS_TABLES.N_COLS to set and test whether the Compact page format is used,...
Definition: dict0mem.h:157
std::list< dict_v_idx_t, ut::allocator< dict_v_idx_t > > dict_v_idx_list
Index list to put in dict_v_col_t.
Definition: dict0mem.h:808
constexpr uint32_t DICT_FK_MAX_RECURSIVE_LOAD
Tables could be chained together with Foreign key constraint.
Definition: dict0mem.h:311
std::list< dict_s_col_t, ut::allocator< dict_s_col_t > > dict_s_col_list
list to put stored column for dict_table_t
Definition: dict0mem.h:855
static uint32_t DICT_MAX_FIELD_LEN_BY_FORMAT_FLAG(uint32_t flags)
Definition: dict0mem.h:880
void dict_table_mutex_destroy(dict_table_t *table)
Destroy the mutex of a given table.
Definition: dict0mem.h:3058
constexpr uint32_t DICT_MULTI_VALUE
Multi-value index.
Definition: dict0mem.h:113
constexpr uint32_t DICT_TF_POS_UNUSED
Zero relative shift position of the start of the UNUSED bits.
Definition: dict0mem.h:211
constexpr uint32_t DICT_TF2_FTS
The table has an FTS index.
Definition: dict0mem.h:276
uint32_t DICT_TF_HAS_SHARED_SPACE(uint32_t flags)
Return the value of the SHARED_SPACE field.
Definition: dict0mem.h:247
const char innobase_index_reserve_name[]
"GEN_CLUST_INDEX" is the name reserved for InnoDB default system clustered index when there is no pri...
Definition: dict0mem.h:1051
constexpr uint32_t DICT_SDI
Definition: dict0mem.h:111
constexpr uint32_t DICT_VIRTUAL
Index on Virtual column.
Definition: dict0mem.h:109
constexpr uint32_t DICT_TF_POS_SHARED_SPACE
Zero relative shift position of the SHARED TABLESPACE field.
Definition: dict0mem.h:208
dict_foreign_t * dict_mem_foreign_create(void)
Creates and initializes a foreign constraint memory object.
Definition: dict0mem.cc:342
constexpr uint32_t DICT_TF_MASK_SHARED_SPACE
Bit mask of the SHARED_SPACE field.
Definition: dict0mem.h:227
void dict_foreign_free(dict_foreign_t *foreign)
Frees a foreign key struct.
Definition: dict0mem.h:1794
std::vector< row_prebuilt_t * > temp_prebuilt_vec
A vector to collect prebuilt from different readers working on the same temp table.
Definition: dict0mem.h:1915
constexpr uint32_t DICT_CORRUPT
bit to store the corrupted flag in SYS_INDEXES.TYPE
Definition: dict0mem.h:103
constexpr uint32_t DICT_TF2_BIT_MASK
Definition: dict0mem.h:267
static void dict_mem_fill_index_struct(dict_index_t *index, mem_heap_t *heap, const char *table_name, const char *index_name, ulint space, ulint type, ulint n_fields)
This function poplulates a dict_index_t index memory structure with supplied information.
static bool DICT_TF2_FLAG_IS_SET(const dict_table_t *table, uint32_t flag)
Definition: dict0mem.h:2752
std::ostream & operator<<(std::ostream &out, const dict_foreign_t &foreign)
Definition: dict0mem.cc:899
constexpr uint32_t DICT_FOREIGN_ON_DELETE_SET_NULL
ON DELETE SET NULL.
Definition: dict0mem.h:1826
constexpr uint32_t DICT_FOREIGN_ON_DELETE_NO_ACTION
ON DELETE NO ACTION.
Definition: dict0mem.h:1832
constexpr uint32_t DICT_TF_COMPACT
dict_table_t::flags bit 0 is equal to 1 if the row format = Compact
Definition: dict0mem.h:153
bool dict_foreign_set_validate(const dict_foreign_set &fk_set)
Validate the search order in the foreign key set.
Definition: dict0mem.cc:850
void dict_mem_table_fill_foreign_vcol_set(dict_table_t *table)
Fill virtual columns set in each fk constraint present in the table.
Definition: dict0mem.cc:521
constexpr uint32_t DICT_TF_POS_ZIP_SSIZE
Zero relative shift position of the ZIP_SSIZE field.
Definition: dict0mem.h:199
constexpr uint32_t DICT_TF2_USE_FILE_PER_TABLE
This bit is used during table creation to indicate that it will use its own tablespace instead of the...
Definition: dict0mem.h:284
constexpr uint32_t DICT_TF_WIDTH_DATA_DIR
If a table is created with the MYSQL option DATA DIRECTORY and innodb-file-per-table,...
Definition: dict0mem.h:177
constexpr uint32_t DICT_TF2_AUX
FTS AUX hidden table bit.
Definition: dict0mem.h:299
constexpr uint32_t DICT_TF_REDUNDANT
dict_table_t::flags bit 0 is equal to 0 if the row format = Redundant
Definition: dict0mem.h:150
dict_v_col_t * dict_mem_table_add_v_col(dict_table_t *table, mem_heap_t *heap, const char *name, ulint mtype, ulint prtype, ulint len, ulint pos, ulint num_base, bool is_visible)
Adds a virtual column definition to a table.
Definition: dict0mem.cc:93
void dict_mem_table_free_foreign_vcol_set(dict_table_t *table)
Free the vcol_set from all foreign key constraint on the table.
Definition: dict0mem.cc:534
constexpr uint32_t DICT_FOREIGN_ON_UPDATE_NO_ACTION
ON UPDATE NO ACTION.
Definition: dict0mem.h:1834
persistent_type_t
Persistent dynamic metadata type, there should be 1 to 1 relationship between the metadata and the ty...
Definition: dict0mem.h:2766
@ PM_BIGGEST_TYPE
The biggest type, which should be 1 bigger than the last true type.
Definition: dict0mem.h:2785
@ PM_TABLE_AUTO_INC
Persistent Metadata type for autoinc counter.
Definition: dict0mem.h:2775
@ PM_INDEX_CORRUPTED
Persistent Metadata type for corrupted indexes.
Definition: dict0mem.h:2772
@ PM_SMALLEST_TYPE
The smallest type, which should be 1 less than the first true type.
Definition: dict0mem.h:2769
constexpr uint32_t FK_MAX_CASCADE_DEL
Similarly, when tables are chained together with foreign key constraints with on cascading delete/upd...
Definition: dict0mem.h:319
constexpr char INSTANT_DROP_PREFIX_8_0_32[]
Definition: dict0mem.h:87
static bool is_valid_row_version(const row_version_t version)
Definition: dict0mem.h:423
uint32_t DICT_TF_GET_ZIP_SSIZE(uint32_t flags)
Return the value of the ZIP_SSIZE field.
Definition: dict0mem.h:235
uint32_t DICT_TF_HAS_DATA_DIR(uint32_t flags)
Return the value of the DATA_DIR field.
Definition: dict0mem.h:243
constexpr uint32_t DICT_MAX_FIXED_COL_LEN
Defines the maximum fixed length column size.
Definition: dict0mem.h:888
constexpr uint32_t DICT_FTS
FTS index; can't be combined with the other flags.
Definition: dict0mem.h:105
constexpr uint32_t DICT_TF2_TEMPORARY
TEMPORARY; true for tables from CREATE TEMPORARY TABLE.
Definition: dict0mem.h:270
ulong zip_pad_max
Maximum percentage of a page that can be allowed as a pad to avoid compression failures.
Definition: dict0dict.cc:183
online_index_status
The status of online index creation.
Definition: dict0mem.h:1645
@ ONLINE_INDEX_ABORTED
secondary index creation was aborted and the index should be dropped as soon as index->table->n_ref_c...
Definition: dict0mem.h:1656
@ ONLINE_INDEX_ABORTED_DROPPED
the online index creation was aborted, the index was dropped from the data dictionary and the tablesp...
Definition: dict0mem.h:1661
@ ONLINE_INDEX_CREATION
the index is being created, online (allowing concurrent modifications)
Definition: dict0mem.h:1650
@ ONLINE_INDEX_COMPLETE
the index is complete and ready for access
Definition: dict0mem.h:1647
constexpr uint32_t DICT_TF2_DISCARDED
Set when we discard/detach the tablespace.
Definition: dict0mem.h:287
constexpr uint32_t DICT_TF2_BITS
Table Flags set number 2.
Definition: dict0mem.h:265
constexpr uint32_t DICT_TF_MASK_DATA_DIR
Bit mask of the DATA_DIR field.
Definition: dict0mem.h:224
constexpr uint32_t DICT_TF2_UNUSED_BIT_MASK
Definition: dict0mem.h:266
ut_list_base< lock_t, TableLockGetNode > table_lock_list_t
Definition: dict0mem.h:1853
constexpr uint32_t DICT_SPATIAL
SPATIAL index; can't be combined with the other flags.
Definition: dict0mem.h:107
constexpr uint32_t DICT_FOREIGN_ON_UPDATE_SET_NULL
ON UPDATE SET NULL.
Definition: dict0mem.h:1830
constexpr uint32_t DICT_TF_POS_ATOMIC_BLOBS
Zero relative shift position of the ATOMIC_BLOBS field.
Definition: dict0mem.h:202
std::set< dict_v_col_t *, std::less< dict_v_col_t * >, ut::allocator< dict_v_col_t * > > dict_vcol_set
Set to store the virtual columns which are affected by Foreign key constraint.
Definition: dict0mem.h:1668
void dict_mem_table_col_rename(dict_table_t *table, ulint nth_col, const char *from, const char *to, bool is_virtual)
Renames a column of a table in the data dictionary cache.
Definition: dict0mem.cc:318
constexpr uint32_t DICT_TF_BITS
Width of all the currently known table flags.
Definition: dict0mem.h:188
static void DICT_TF2_FLAG_SET(dict_table_t *table, uint32_t flag)
Definition: dict0mem.h:2748
constexpr uint32_t DICT_TF_MASK_ATOMIC_BLOBS
Bit mask of the ATOMIC_BLOBS field.
Definition: dict0mem.h:221
constexpr uint32_t ZIP_PAD_ROUND_LEN
PADDING HEURISTIC BASED ON LINEAR INCREASE OF PADDING TO AVOID COMPRESSION FAILURES (Note: this is re...
Definition: dict0mem.h:939
void dict_mem_table_add_s_col(dict_table_t *table, ulint num_base)
Adds a stored column definition to a table.
Definition: dict0mem.cc:150
constexpr uint32_t DICT_FOREIGN_ON_DELETE_CASCADE
The flags for ON_UPDATE and ON_DELETE can be ORed; the default is that a foreign key constraint is en...
Definition: dict0mem.h:1824
uint32_t DICT_TF_GET_COMPACT(uint32_t flags)
Return the value of the COMPACT field.
Definition: dict0mem.h:231
constexpr uint32_t ZIP_PAD_SUCCESSFUL_ROUND_LIMIT
Number of successful rounds after which the padding is decreased.
Definition: dict0mem.h:942
void dict_index_zip_pad_mutex_create_lazy(dict_index_t *index)
Request a lazy creation of dict_index_t::zip_pad::mutex.
Definition: dict0mem.h:3099
constexpr uint32_t DICT_UNIQUE
unique index
Definition: dict0mem.h:99
constexpr uint32_t DICT_TABLE_MAGIC_N
Value of 'magic_n'.
Definition: dict0mem.h:1920
constexpr uint32_t ZIP_PAD_INCR
Amount by which padding is increased.
Definition: dict0mem.h:945
constexpr uint32_t DICT_IBUF
insert buffer tree
Definition: dict0mem.h:101
constexpr uint32_t DICT_TF_MASK_COMPACT
Bit mask of the COMPACT field.
Definition: dict0mem.h:215
constexpr uint32_t DICT_INDEX_MAGIC_N
Value of dict_index_t::magic_n.
Definition: dict0mem.h:1059
void dict_table_autoinc_destroy(dict_table_t *table)
Destroy the autoinc latch of the given table.
Definition: dict0mem.h:3071
uint32_t DICT_TF_HAS_ATOMIC_BLOBS(uint32_t flags)
Return the value of the ATOMIC_BLOBS field.
Definition: dict0mem.h:239
constexpr uint32_t DICT_TF2_FTS_HAS_DOC_ID
The table has an internal defined DOC ID column.
Definition: dict0mem.h:273
constexpr uint32_t DICT_TF_POS_DATA_DIR
Zero relative shift position of the DATA_DIR field.
Definition: dict0mem.h:205
bool dict_table_autoinc_own(const dict_table_t *table)
Check if the current thread owns the autoinc_mutex of a given table.
Definition: dict0mem.h:3129
constexpr uint32_t DICT_TF_WIDTH_COMPACT
Width of the COMPACT flag.
Definition: dict0mem.h:160
constexpr char RECOVERY_INDEX_TABLE_NAME[]
index/table name used while applying REDO logs during recovery
Definition: dict0mem.h:90
constexpr uint32_t DICT_FOREIGN_ON_UPDATE_CASCADE
ON UPDATE CASCADE.
Definition: dict0mem.h:1828
constexpr uint32_t DICT_TF2_INTRINSIC
Intrinsic table bit Intrinsic table is table created internally by MySQL modules viz.
Definition: dict0mem.h:293
constexpr uint32_t DICT_TF2_RESURRECT_PREPARED
Table is opened by resurrected trx during crash recovery.
Definition: dict0mem.h:302
uint32_t DICT_TF_GET_UNUSED(uint32_t flags)
Return the contents of the UNUSED bits.
Definition: dict0mem.h:251
void dict_mem_referenced_table_name_lookup_set(dict_foreign_t *foreign, bool do_alloc)
Sets the referenced_table_name_lookup pointer based on the value of lower_case_table_names.
Definition: dict0mem.cc:389
constexpr uint32_t DICT_INDEX_MERGE_THRESHOLD_DEFAULT
Definition: dict0mem.h:1062
void dict_mem_index_free(dict_index_t *index)
Frees an index memory object.
Definition: dict0mem.cc:766
constexpr uint32_t DICT_TF_POS_COMPACT
Zero relative shift position of the COMPACT field.
Definition: dict0mem.h:197
constexpr uint32_t DICT_TF_WIDTH_ZIP_SSIZE
Width of the ZIP_SSIZE flag.
Definition: dict0mem.h:163
void dict_table_mutex_create_lazy(dict_table_t *table)
Request for lazy creation of the mutex of a given table.
Definition: dict0mem.h:3049
constexpr uint32_t DICT_ANTELOPE_MAX_INDEX_COL_LEN
DICT_ANTELOPE_MAX_INDEX_COL_LEN is measured in bytes and is the maximum indexed column length (or ind...
Definition: dict0mem.h:868
std::vector< index_id_t, ut::allocator< index_id_t > > corrupted_ids_t
Definition: dict0mem.h:2788
constexpr uint32_t DICT_TF_MASK_ZIP_SSIZE
Bit mask of the ZIP_SSIZE field.
Definition: dict0mem.h:218
constexpr uint32_t DICT_TF_WIDTH_ATOMIC_BLOBS
Width of the ATOMIC_BLOBS flag.
Definition: dict0mem.h:171
void dict_index_zip_pad_unlock(dict_index_t *index)
Release the zip_pad_mutex of a given index.
Definition: dict0mem.h:3119
Data dictionary memory object creation.
Data dictionary global types.
ib_id_t space_index_t
Index identifier (unique within a tablespace).
Definition: dict0types.h:223
spatial_status_t
whether a col is used in spatial index or regular index Note: the spatial status is part of persisten...
Definition: dict0types.h:335
@ SPATIAL_MIXED
Used in both spatial index and regular index.
Definition: dict0types.h:343
@ SPATIAL_NONE
Not used in gis index.
Definition: dict0types.h:340
@ SPATIAL_ONLY
Only used in spatial index.
Definition: dict0types.h:346
ib_id_t table_id_t
Table or partition identifier (unique within an InnoDB instance).
Definition: dict0types.h:221
ib_quiesce_t
Quiescing states for flushing tables to disk.
Definition: dict0types.h:300
Full text search header file.
R-tree header file.
The simple hash table utility.
void * hash_node_t
Definition: hash0hash.h:47
static int flags[50]
Definition: hp_test1.cc:40
static int flag
Definition: hp_test1.cc:40
The transaction lock system global types.
@ LOCK_NUM
Definition: lock0types.h:62
The memory management.
static void mem_heap_free(mem_heap_t *heap)
Frees the space occupied by a memory heap.
Data dictionary memory object creation.
#define mtr_commit(m)
Commit a mini-transaction.
Definition: mtr0mtr.h:59
void for_each(const Shards< COUNT > &shards, Function &&f) noexcept
Iterate over the shards.
Definition: ut0counter.h:323
static PFS_engine_table_share_proxy table
Definition: pfs.cc:61
const dd::String_type MYSQL_SCHEMA_NAME
Definition: server.cc:254
The version of the current data dictionary table definitions.
Definition: dictionary_client.h:44
unsigned long long Object_id
Definition: object_id.h:31
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
bool index(const std::string &value, const String &search_for, uint32_t *idx)
Definition: contains.h:76
ValueType value(const std::optional< ValueType > &v)
Definition: gtid.h:83
size_t size(const char *const c)
Definition: base64.h:46
mutable_buffer buffer(void *p, size_t n) noexcept
Definition: buffer.h:418
const char * table_name
Definition: rules_table_service.cc:56
void delete_(T *ptr) noexcept
Releases storage which has been dynamically allocated through any of the ut::new*() variants.
Definition: ut0new.h:811
std::set< Key, Compare, ut::allocator< Key > > set
Specialization of set which uses ut_allocator.
Definition: ut0new.h:2888
std::map< Key, Value, Compare, ut::allocator< std::pair< const Key, Value > > > map
Specialization of map which uses ut_allocator.
Definition: ut0new.h:2898
A class that aids executing a given function exactly once in a multi-threaded environment.
Query graph global types.
Record manager global types.
const uint8_t MAX_ROW_VERSION
Definition: rem0types.h:46
constexpr uint32_t REC_ANTELOPE_MAX_INDEX_COL_LEN
Definition: rem0types.h:82
constexpr uint32_t REC_VERSION_56_MAX_INDEX_COL_LEN
Maximum indexed field length for tables that have atomic BLOBs.
Definition: rem0types.h:87
const row_version_t INVALID_ROW_VERSION
Definition: rem0types.h:56
byte rec_t
Definition: rem0types.h:41
uint16_t row_version_t
Definition: rem0types.h:53
required uint64 version
Definition: replication_group_member_actions.proto:41
required string type
Definition: replication_group_member_actions.proto:34
Row operation global types.
LEX_CSTRING INFORMATION_SCHEMA_NAME
Definition: table.cc:137
File containing constants that can be used throughout the server.
constexpr const unsigned int MAX_KEY_LENGTH
Definition: sql_const.h:47
case opt name
Definition: sslopt-case.h:29
const char * str
Definition: mysql_lex_string.h:41
Definition: lock0priv.h:283
The search info struct in an index.
Definition: btr0sea.h:46
The buffer control block structure.
Definition: buf0buf.h:1764
Data structure for newly added virtual column in a table.
Definition: dict0mem.h:831
const dict_v_col_t * v_col
column structures
Definition: dict0mem.h:836
ulint n_v_col
number of new virtual column
Definition: dict0mem.h:833
const char ** v_col_name
new col names
Definition: dict0mem.h:839
Data structure for default value of a column in a table.
Definition: dict0mem.h:472
byte * value
Default value in bytes.
Definition: dict0mem.h:476
dict_col_t * col
Pointer to the column itself.
Definition: dict0mem.h:474
size_t len
Length of default value.
Definition: dict0mem.h:478
bool operator!=(const dict_col_default_t &other) const
Definition: dict0mem.cc:598
bool operator==(const dict_col_default_t &other) const
Definition: dict0mem.cc:576
Data structure for a column in a table.
Definition: dict0mem.h:485
uint16_t get_col_phy_pos() const
Definition: dict0mem.h:567
void copy_type(dtype_t *type) const
Gets the column data type.
Definition: dict0mem.h:663
unsigned ord_part
nonzero if this column appears in the ordering fields of an index
Definition: dict0mem.h:526
bool is_dropped_in_or_before(row_version_t version) const
Check if column is dropped before the given version.
Definition: dict0mem.h:736
void set_phy_pos(uint32_t pos)
Definition: dict0mem.h:579
void set_prefix_phy_pos(uint16_t prefix_pos)
Definition: dict0mem.h:560
row_version_t get_version_added() const
Definition: dict0mem.h:588
spatial_status_t get_spatial_status() const
Check whether the col is used in spatial index or regular index.
Definition: dict0mem.h:706
ulint get_null_size(ulint comp) const
Returns the ROW_FORMAT=REDUNDANT stored SQL NULL size of a column.
Definition: dict0mem.h:702
row_version_t version_added
Definition: dict0mem.h:544
bool is_visible
Definition: dict0mem.h:535
unsigned mtype
main data type
Definition: dict0mem.h:502
unsigned max_prefix
maximum index prefix length on this column.
Definition: dict0mem.h:529
ulint get_fixed_size(ulint comp) const
Returns the size of a fixed size column, 0 if not a fixed size column.
Definition: dict0mem.h:694
bool is_version_added_match(const dict_col_t *col) const
Definition: dict0mem.h:598
static bool is_instant_dropped_name(const std::string col_name)
Check if a column name resembles format for dropped column.
Definition: dict0mem.h:787
bool is_instant_added() const
Definition: dict0mem.h:581
ulint get_min_size() const
Returns the minimum size of the column.
Definition: dict0mem.h:641
void set_default(const byte *value, size_t length, mem_heap_t *heap)
Set default value.
Definition: dict0mem.cc:552
ulint get_mbminlen() const
Gets the minimum number of bytes per character.
Definition: dict0mem.h:674
bool is_version_dropped_match(const dict_col_t *col) const
Definition: dict0mem.h:627
bool is_nullable() const
Check if a column is nullable.
Definition: dict0mem.h:659
bool is_visible_in_version(row_version_t version) const
Check if a column is visible in given version.
Definition: dict0mem.h:762
void set_version_added(row_version_t version)
Definition: dict0mem.h:593
void set_col_phy_pos(uint16_t pos)
Definition: dict0mem.h:570
bool is_instant_dropped() const
Definition: dict0mem.h:610
bool is_multi_value() const
Check if a column is a multi-value virtual column.
Definition: dict0mem.h:655
row_version_t version_dropped
Definition: dict0mem.h:547
uint32_t phy_pos
Definition: dict0mem.h:541
ulint get_max_size() const
Returns the maximum size of the column.
Definition: dict0mem.h:647
bool is_added_after(row_version_t version) const
Check if column is added after the current version.
Definition: dict0mem.h:749
bool assert_equal(const dtype_t *type) const
Assert that a column and a data type match.
Definition: dict0mem.h:771
unsigned len
length; for MySQL data this is field->pack_length(), except that for a >= 5.0.3 type true VARCHAR thi...
Definition: dict0mem.h:506
dict_col_default_t * instant_default
The following are copied from dtype_t, so that all bit-fields can be packed tightly.
Definition: dict0mem.h:493
uint16_t get_prefix_phy_pos() const
Definition: dict0mem.h:554
bool is_virtual() const
Check if a column is a virtual column.
Definition: dict0mem.h:651
unsigned mbminmaxlen
minimum and maximum length of a character, in bytes; DATA_MBMINMAXLEN(mbminlen,mbmaxlen); mbminlen=DA...
Definition: dict0mem.h:515
row_version_t get_version_dropped() const
Definition: dict0mem.h:617
void set_version_dropped(row_version_t version)
Definition: dict0mem.h:622
void set_mbminmaxlen(ulint mbminlen, ulint mbmaxlen)
Sets the minimum and maximum number of bytes per character.
Definition: dict0mem.h:683
unsigned ind
table column position (starting from 0)
Definition: dict0mem.h:524
unsigned prtype
precise type; MySQL data type, charset code, flags to indicate nullability, signedness,...
Definition: dict0mem.h:495
ulint get_mbmaxlen() const
Gets the maximum number of bytes per character.
Definition: dict0mem.h:678
bool has_prefix_phy_pos() const
Definition: dict0mem.h:551
uint32_t get_phy_pos() const
Definition: dict0mem.h:576
Data structure for a field in an index.
Definition: dict0mem.h:891
dict_col_t * col
pointer to the table column
Definition: dict0mem.h:894
id_name_t name
name of the column
Definition: dict0mem.h:895
unsigned is_ascending
0=DESC, 1=ASC
Definition: dict0mem.h:907
unsigned prefix_len
0 or the length of the column prefix in bytes in a MySQL index of type, e.g., INDEX (textcol(25)); mu...
Definition: dict0mem.h:896
unsigned fixed_len
0 or the fixed length of the column if smaller than DICT_ANTELOPE_MAX_INDEX_COL_LEN
Definition: dict0mem.h:904
uint16_t get_phy_pos() const
Definition: dict0mem.h:909
dict_field_t()
Definition: dict0mem.h:892
A function object to add the foreign key constraint to the referenced set of the referenced table,...
Definition: dict0mem.h:3035
void operator()(dict_foreign_t *foreign) const
Definition: dict0mem.h:3036
Compare two dict_foreign_t objects using their ids.
Definition: dict0mem.h:1734
bool operator()(const dict_foreign_t *lhs, const dict_foreign_t *rhs) const
Definition: dict0mem.h:1735
Definition: dict0mem.h:1755
bool operator()(const dict_foreign_t *foreign) const
Definition: dict0mem.h:1756
Function object to check if a foreign key object is there in the given foreign key set or not.
Definition: dict0mem.h:1770
bool operator()(dict_foreign_t *const &foreign) const
Definition: dict0mem.h:1774
const dict_foreign_set & m_foreigns
Definition: dict0mem.h:1779
dict_foreign_not_exists(const dict_foreign_set &obj_)
Definition: dict0mem.h:1771
Definition: dict0mem.h:1721
void operator()(const dict_foreign_t *foreign)
Definition: dict0mem.h:1724
dict_foreign_print(std::ostream &out)
Definition: dict0mem.h:1722
std::ostream & m_out
Definition: dict0mem.h:1727
The destructor will free all the foreign key constraints in the set by calling dict_foreign_free() on...
Definition: dict0mem.h:1808
~dict_foreign_set_free()
Definition: dict0mem.h:1812
dict_foreign_set_free(const dict_foreign_set &foreign_set)
Definition: dict0mem.h:1809
const dict_foreign_set & m_foreign_set
Definition: dict0mem.h:1817
Data structure for a foreign key constraint; an example: FOREIGN KEY (A, B) REFERENCES TABLE2 (C,...
Definition: dict0mem.h:1673
unsigned type
0 or DICT_FOREIGN_ON_DELETE_CASCADE or DICT_FOREIGN_ON_DELETE_SET_NULL
Definition: dict0mem.h:1684
char * referenced_table_name_lookup
referenced table name for dict lookup
Definition: dict0mem.h:1693
dict_vcol_set * v_cols
set of virtual columns affected by foreign key constraint.
Definition: dict0mem.h:1706
char * referenced_table_name
referenced table name
Definition: dict0mem.h:1692
dict_table_t * referenced_table
table where the referenced key is
Definition: dict0mem.h:1695
char * foreign_table_name_lookup
foreign table name used for dict lookup
Definition: dict0mem.h:1687
const char ** referenced_col_names
names of the referenced columns in the referenced table
Definition: dict0mem.h:1697
const char ** foreign_col_names
names of the columns in the foreign key
Definition: dict0mem.h:1690
unsigned n_fields
number of indexes' first fields for which the foreign key constraint is defined: we allow the indexes...
Definition: dict0mem.h:1678
bool is_fts_col_affected() const
Check whether foreign key constraint contains a column with a full index on it.
Definition: dict0mem.cc:876
dict_table_t * foreign_table
table where the foreign key is
Definition: dict0mem.h:1689
char * foreign_table_name
foreign table name
Definition: dict0mem.h:1686
mem_heap_t * heap
this object is allocated from this memory heap
Definition: dict0mem.h:1674
dict_index_t * referenced_index
referenced index
Definition: dict0mem.h:1704
char * id
id of the constraint as a null-terminated string
Definition: dict0mem.h:1676
dict_index_t * foreign_index
foreign index; we require that both tables contain explicitly defined indexes for the constraint: Inn...
Definition: dict0mem.h:1699
A function object to find a foreign key with the given index as the referenced index.
Definition: dict0mem.h:1742
const dict_index_t * m_index
Definition: dict0mem.h:1749
dict_foreign_with_index(const dict_index_t *index)
Definition: dict0mem.h:1743
bool operator()(const dict_foreign_t *foreign) const
Definition: dict0mem.h:1745
Data structure storing index statistics.
Definition: dict0mem.h:3138
dict_index_stats_t stats
Definition: dict0mem.h:3139
unsigned type
Definition: dict0mem.h:3140
unsigned n_uniq
Definition: dict0mem.h:3141
Data structure storing index statistics for query optimization.
Definition: dict0mem.h:1025
uint64_t * n_sample_sizes
number of pages that were sampled to calculate each of n_diff_key_vals[], e.g.
Definition: dict0mem.h:1035
ulint index_size
approximate index size in database pages
Definition: dict0mem.h:1043
uint64_t * n_non_null_key_vals
Definition: dict0mem.h:1040
uint64_t * n_diff_key_vals
approximate number of different key values for this index, for each n-column prefix where 1 <= n <= d...
Definition: dict0mem.h:1030
ulint n_leaf_pages
approximate number of leaf pages in the index tree
Definition: dict0mem.h:1046
Data structure for an index.
Definition: dict0mem.h:1067
uint32_t get_n_nullable_before(uint32_t nth) const
Returns the number of nullable fields before specified nth field.
Definition: dict0mem.h:1371
bool is_committed() const
Determine if the index has been committed to the data dictionary.
Definition: dict0mem.h:1274
unsigned uncommitted
a flag that is set for secondary indexes that have not been committed to the data dictionary yet
Definition: dict0mem.h:1152
const char * table_name
table name
Definition: dict0mem.h:1078
const dict_index_t * next() const
Get the next index.
Definition: dict0mem.h:1290
unsigned instant_cols
true if the index is clustered index and it has some instant columns
Definition: dict0mem.h:1155
rtr_ssn_t rtr_ssn
Node sequence number for RTree.
Definition: dict0mem.h:1231
rw_lock_t lock
read-write lock protecting the upper levels of the index tree
Definition: dict0mem.h:1244
id_name_t name
index name
Definition: dict0mem.h:1075
const byte * get_nth_default(ulint nth, ulint *length) const
Get the default value of nth field and its length if exists.
Definition: dict0mem.h:1578
dict_index_stats_t stats
Statistics for query optimization.
Definition: dict0mem.h:1214
unsigned type
index type (DICT_CLUSTERED, DICT_UNIQUE, DICT_IBUF, DICT_CORRUPT)
Definition: dict0mem.h:1094
uint32_t magic_n
magic number
Definition: dict0mem.h:1171
uint32_t get_nullable_in_version(row_version_t version) const
Return nullable in a specific row version.
Definition: dict0mem.h:1439
uint32_t get_n_total_fields() const
Returns total fields including INSTANT DROP fields.
Definition: dict0mem.h:1389
bool has_instant_cols_or_row_versions() const
check if either instant or versioned.
Definition: dict0mem.h:1355
void destroy_fields_array()
Definition: dict0mem.h:1458
unsigned n_total_fields
number of total fields in the index (including INSTANT dropped fields)
Definition: dict0mem.h:1130
dict_field_t * get_physical_field(size_t pos) const
Gets the nth physical pos field.
Definition: dict0mem.h:1491
uint32_t get_instant_fields() const
Returns the number of fields before first instant ADD COLUMN.
Definition: dict0mem.ic:92
unsigned trx_id_offset
position of the trx id column in a clustered index record, if the fields before it are known to be of...
Definition: dict0mem.h:1098
void create_fields_array()
Create fields array sorted by phy_pos of field in row.
Definition: dict0mem.h:1446
uint16_t get_field_off_pos(ulint pos) const
Get the physical position of a field on a row.
Definition: dict0mem.h:1529
void set_instant_nullable(uint16_t n)
Set instant nullable.
Definition: dict0mem.h:1251
trx_id_t trx_id
id of the transaction that created this index, or 0 if the index existed when InnoDB was started up
Definition: dict0mem.h:1238
bool fill_dd
Flag whether need to fill dd tables when it's a fulltext index.
Definition: dict0mem.h:1247
const dict_col_t * get_col(ulint pos) const
Gets pointer to the nth column in an index.
Definition: dict0mem.h:1552
std::unique_ptr< dd::Spatial_reference_system > rtr_srs
Cached spatial reference system dictionary entry used by R-tree indexes.
Definition: dict0mem.h:1168
dict_field_t * fields
array of field descriptions
Definition: dict0mem.h:1175
uint32_t srid
spatial reference id
Definition: dict0mem.h:1161
last_ops_cur_t * last_ins_cur
cache the last insert position.
Definition: dict0mem.h:1219
ulint get_col_pos(ulint n, bool inc_prefix=false, bool is_virtual=false) const
Looks for column n in an index.
Definition: dict0mem.cc:733
space_id_t space_id() const
Get the space id of the tablespace to which this index belongs.
Definition: dict0mem.h:1637
uint32_t has_multi_value_col(const dict_v_col_t *mv_col) const
Check if a multi-value index is built on specified multi-value virtual column.
Definition: dict0mem.h:1613
void add_field(const char *name_arg, ulint prefix_len, bool is_ascending)
Adds a field definition to an index.
Definition: dict0mem.h:1474
uint16_t get_instant_nullable() const
Get instant nullable.
Definition: dict0mem.h:1255
unsigned nulls_equal
if true, SQL NULL == SQL NULL
Definition: dict0mem.h:1112
bool is_usable(const trx_t *trx) const
Check whether index can be used by transaction.
Definition: dict0mem.cc:604
UT_LIST_NODE_T(dict_index_t) indexes
list of indexes of the table
unsigned row_versions
true if the index is clustered index and table has row versions
Definition: dict0mem.h:1158
bool is_fts_index() const
Check if it is a full-text search (FTS) index.
Definition: dict0mem.h:1641
uint16_t get_field_phy_pos(ulint pos, row_version_t version) const
Definition: dict0mem.h:1533
unsigned n_instant_nullable
number of nullable fields before first instant ADD COLUMN applied to this table.
Definition: dict0mem.h:1137
unsigned space
space where the index tree is placed
Definition: dict0mem.h:1084
unsigned cached
true if the index object is in the dictionary cache
Definition: dict0mem.h:1140
ulint get_sys_col_pos(ulint type) const
Returns the position of a system column in an index.
Definition: dict0mem.cc:716
zip_pad_info_t zip_pad
Information about state of compression failures and successes.
Definition: dict0mem.h:1241
dict_field_t * get_field(ulint pos) const
Gets the nth field of an index.
Definition: dict0mem.h:1505
row_log_t * online_log
the log of modifications during online index creation; valid when online_status is ONLINE_INDEX_CREAT...
Definition: dict0mem.h:1208
uint16_t get_nullable_before_instant_add_drop() const
Get the nullable fields before any INSTANT ADD/DROP.
Definition: dict0mem.h:1259
unsigned disable_ahi
if true, then disable AHI.
Definition: dict0mem.h:1117
ulint get_min_size() const
Returns the minimum data size of an index record.
Definition: dict0mem.h:1330
size_t calculate_n_instant_nullable(size_t _n_fields) const
Definition: dict0mem.h:1398
unsigned n_def
number of fields defined so far
Definition: dict0mem.h:1124
unsigned n_nullable
number of nullable fields
Definition: dict0mem.h:1133
rec_cache_t rec_cache
cache the field that needs to be re-computed on each insert.
Definition: dict0mem.h:1228
bool is_multi_value() const
Check whether the index is the multi-value index.
Definition: dict0mem.h:1322
last_ops_cur_t * last_sel_cur
cache the last selected position.
Definition: dict0mem.h:1223
unsigned n_fields
number of fields in the index
Definition: dict0mem.h:1127
uint16_t get_logical_pos(uint16_t phy_pos) const
Given the physical position, find the logical position of field.
Definition: dict0mem.h:1515
st_mysql_ftparser * parser
fulltext parser plugin
Definition: dict0mem.h:1187
uint32_t nullables[MAX_ROW_VERSION+1]
Number of nullable columns in each version.
Definition: dict0mem.h:1183
bool has_row_versions() const
Check whether index belongs to a table having row versions.
Definition: dict0mem.h:1351
space_index_t id
id of the index
Definition: dict0mem.h:1069
void set_committed(bool committed)
Flag an index committed or uncommitted.
Definition: dict0mem.h:1281
bool is_compressed() const
Check if the underlying table is compressed.
Definition: dict0mem.h:2761
void create_nullables(uint32_t current_row_version)
Create nullables array.
Definition: dict0mem.cc:622
bool is_corrupted() const
Check whether the index is corrupted.
Definition: dict0mem.h:1305
bool srid_is_valid
says whether SRID is valid - it cane be undefined
Definition: dict0mem.h:1164
rtr_info_track_t * rtr_track
tracking all R-Tree search cursors
Definition: dict0mem.h:1234
dict_index_t * next()
Get the next index.
Definition: dict0mem.h:1298
bool is_clustered() const
Definition: dict0mem.h:1314
bool has_instant_cols() const
Check whether index has any instantly added columns.
Definition: dict0mem.h:1347
ulint get_col_no(ulint pos) const
Gets the column number the nth field in an index.
Definition: dict0mem.cc:709
mem_heap_t * heap
memory heap
Definition: dict0mem.h:1072
unsigned merge_threshold
In the pessimistic delete, if the page data size drops below this limit in percent,...
Definition: dict0mem.h:1091
std::vector< uint16_t > fields_array
Array of field pos sorted as per their physical pos in record.
Definition: dict0mem.h:1179
dict_table_t * table
back pointer to table
Definition: dict0mem.h:1081
bool is_ngram
true if it's ngram parser
Definition: dict0mem.h:1190
unsigned online_status
enum online_index_status.
Definition: dict0mem.h:1148
bool has_new_v_col
whether it has a newly added virtual column in ALTER
Definition: dict0mem.h:1193
page_size_t get_page_size() const
Get the page size of the tablespace to which this index belongs.
Definition: dict0mem.cc:917
bool is_tuple_instant_format(const uint16_t n_fields_in_tuple) const
Check if tuple is having instant format.
Definition: dict0mem.cc:672
unsigned allow_duplicates
if true, allow duplicate values even if index is created with unique constraint
Definition: dict0mem.h:1109
void fill_srid_value(uint32_t srid_value, bool srid_is_valid_value)
Sets srid and srid_is_valid values.
Definition: dict0mem.h:1597
bool hidden
if the index is an hidden index
Definition: dict0mem.h:1196
unsigned page
index tree root page number
Definition: dict0mem.h:1087
unsigned n_user_defined_cols
number of columns the user defined to be in the index: in the internal representation we add more col...
Definition: dict0mem.h:1101
btr_search_t * search_info
info used in optimistic searches
Definition: dict0mem.h:1203
unsigned to_be_dropped
true if the index is to be dropped; protected by dict_operation_lock
Definition: dict0mem.h:1143
unsigned n_uniq
number of fields from the beginning which are enough to determine an index entry uniquely
Definition: dict0mem.h:1121
Data structure for a stored column in a table.
Definition: dict0mem.h:843
dict_col_t * m_col
Stored column ptr.
Definition: dict0mem.h:845
ulint s_pos
column pos in table
Definition: dict0mem.h:851
dict_col_t ** base_col
array of base col ptr
Definition: dict0mem.h:847
ulint num_base
number of base columns
Definition: dict0mem.h:849
Data structure for a database table.
Definition: dict0mem.h:1925
uint32_t stats_auto_recalc
Indicates whether the table uses automatic recalc for persistent stats or not.
Definition: dict0mem.h:2281
bool has_instant_cols() const
Definition: dict0mem.h:2518
bool refresh_fk
refresh/reload FK info
Definition: dict0mem.h:2470
bool support_instant_add_drop() const
Determine if the table can support instant ADD/DROP COLUMN.
Definition: dict0dict.ic:1248
dict_vcol_templ_t * vc_templ
mysql_row_templ_t for base columns used for compute the virtual columns
Definition: dict0mem.h:2464
dict_col_t * get_col_by_name(const char *name) const
Get column by name.
Definition: dict0mem.h:2624
bool has_row_versions() const
Definition: dict0mem.h:2503
unsigned n_cols
Number of non-virtual columns.
Definition: dict0mem.h:2067
rw_lock_t * stats_latch
This latch protects: "dict_table_t::stat_initialized", "dict_table_t::stat_n_rows (*)",...
Definition: dict0mem.h:2229
std::atomic< const trx_t * > autoinc_trx
The transaction that currently holds the the AUTOINC lock on this table.
Definition: dict0mem.h:2391
ulint stat_clustered_index_size
Approximate clustered index size in database pages.
Definition: dict0mem.h:2293
uint32_t get_n_instant_add_cols() const
Get number of columns added instantly.
Definition: dict0mem.h:2551
void unlock()
Unlock the table handle.
Definition: dict0dict.ic:1089
const char * get_col_name(ulint col_nr) const
Returns a column's name.
Definition: dict0mem.h:2597
std::atomic< int8_t > stats_bg_flag
The state of the background stats thread wrt this table.
Definition: dict0mem.h:2325
std::atomic< ulint > n_foreign_key_checks_running
Count of how many foreign key check operations are currently being performed on the table.
Definition: dict0mem.h:2185
unsigned drop_aborted
true if some indexes should be dropped after ONLINE_INDEX_ABORTED or ONLINE_INDEX_ABORTED_DROPPED.
Definition: dict0mem.h:2099
ulint magic_n
Magic number.
Definition: dict0mem.h:2460
dict_foreign_set foreign_set
set of foreign key constraints which refer to this table
Definition: dict0mem.h:2194
UT_LIST_BASE_NODE_T(dict_index_t, indexes) indexes
List of indexes of the table.
bool skip_gap_locks() const
Definition: dict0dict.ic:1243
table_lock_list_t locks
List of locks on the table.
Definition: dict0mem.h:2426
unsigned to_be_dropped
true if the table is to be dropped, but not yet actually dropped (could in the background drop list).
Definition: dict0mem.h:2061
dict_col_t * get_col(uint pos) const
Gets the nth column of a table.
Definition: dict0mem.h:2614
uint64_t version
metadata version number of dd::Table::se_private_data()
Definition: dict0mem.h:2148
id_name_t tablespace
NULL or the tablespace name that this table is assigned to, specified by the TABLESPACE option.
Definition: dict0mem.h:2010
unsigned ibd_file_missing
true if this is in a single-table tablespace and the .ibd file is missing.
Definition: dict0mem.h:2051
hash_node_t name_hash
Hash chain node.
Definition: dict0mem.h:2131
unsigned n_instant_cols
Number of non-virtual columns before first instant ADD COLUMN, including the system columns like n_co...
Definition: dict0mem.h:2072
unsigned n_v_def
Number of virtual columns defined so far.
Definition: dict0mem.h:2081
ulint stats_sample_pages
The number of pages to sample for this table during persistent stats estimation.
Definition: dict0mem.h:2286
size_t get_index_count() const
Definition: dict0mem.h:2142
unsigned skip_alter_undo
true if the table is an intermediate table during copy alter operation or a partition/subpartition wh...
Definition: dict0mem.h:2046
bool explicitly_non_lru
true if this table is explicitly put to non-LRU list during table creation
Definition: dict0mem.h:2484
bool is_system_table
True if the table belongs to a system database (mysql, information_schema or performance_schema)
Definition: dict0mem.h:2128
std::atomic< size_t > n_rec_locks
Count of the number of record locks on this table.
Definition: dict0mem.h:2413
size_t get_n_instant_added_col_v1() const
Definition: dict0mem.h:2541
unsigned flags2
Stores information about: 1 whether the table has been created using CREATE TEMPORARY TABLE,...
Definition: dict0mem.h:2039
void lock()
Lock the table handle.
Definition: dict0dict.ic:1080
ib_quiesce_t quiesce
Quiescing states, protected by the dict_index_t::lock.
Definition: dict0mem.h:2403
bool has_pk() const
Check if the table has user defined primary key (PK).
Definition: dict0mem.cc:921
unsigned n_t_def
Number of total columns defined so far.
Definition: dict0mem.h:2078
void set_instant_cols(uint16_t n_inst_cols)
Set the number of columns when the first instant ADD COLUMN happens.
Definition: dict0mem.h:2530
unsigned flags
Stores information about: 1 row format (redundant or compact), 2 compressed page size (zip shift size...
Definition: dict0mem.h:2026
ulint autoinc_field_no
The position of autoinc counter field in clustered index.
Definition: dict0mem.h:2383
uint64_t sess_row_id
row-id counter for use by intrinsic table for getting row-id.
Definition: dict0mem.h:2444
void acquire()
Acquire the table handle.
Definition: dict0dict.ic:1038
uint16_t get_instant_cols() const
Get the number of user columns when the first instant ADD COLUMN happens.
Definition: dict0mem.h:2537
std::atomic< table_dirty_status > dirty_status
table dynamic metadata status, protected by dict_persist->mutex
Definition: dict0mem.h:2166
table_id_t id
Id of the table.
Definition: dict0mem.h:1986
UT_LIST_NODE_T(dict_table_t) table_LRU
Node of the LRU list of tables.
unsigned cached
true if the table object has been added to the dictionary cache.
Definition: dict0mem.h:2054
dict_s_col_t * is_stored_gcol(dict_col_t *col) const
Check if the given column is a stored generated column.
Definition: dict0mem.h:2737
dict_index_t * first_index()
Definition: dict0mem.h:2497
bool is_temporary() const
Determine if this is a temporary table.
Definition: dict0mem.h:2699
bool discard_after_ddl
remove the dict_table_t from cache after DDL operation
Definition: dict0mem.h:2467
uint16_t get_n_user_cols() const
Gets the number of user-defined non-virtual columns in a table in the dictionary cache.
Definition: dict0mem.h:2644
void acquire_with_lock()
Acquire the table handle, with lock() and unlock() the table.
Definition: dict0dict.ic:1044
trx_id_t def_trx_id
Transaction id that last touched the table definition.
Definition: dict0mem.h:2190
ulint get_total_cols() const
Gets the number of all non-virtual columns in a table including columns dropped INSTANTly.
Definition: dict0mem.h:2672
dd::Object_id dd_space_id
dd::Tablespace::id of the table
Definition: dict0mem.h:2016
uint32_t total_col_count
Total non-virtual column count.
Definition: dict0mem.h:2160
dict_s_col_list * s_cols
List of stored column descriptions.
Definition: dict0mem.h:2112
unsigned n_m_v_cols
Number of multi-value virtual columns.
Definition: dict0mem.h:2087
unsigned n_t_cols
Number of total columns (include virtual and non-virtual)
Definition: dict0mem.h:2075
ib_mutex_t * mutex
Mutex of the table for concurrency access.
Definition: dict0mem.h:1979
table_id_t parent_id
If FTS AUX table, parent table id.
Definition: dict0mem.h:2299
uint64_t stat_modified_counter
How many rows are modified since last stats recalc.
Definition: dict0mem.h:2307
void release()
Release the table handle.
Definition: dict0dict.ic:1060
bool is_compressed() const
Check if the table is compressed.
Definition: dict0mem.h:1928
uint64_t autoinc
Autoinc counter value to give to the next inserted row.
Definition: dict0mem.h:2357
ulint stat_sum_of_other_index_sizes
Approximate size of other indexes in database pages.
Definition: dict0mem.h:2296
dict_col_t * get_sys_col(ulint sys) const
Gets the given system column of a table.
Definition: dict0mem.h:2685
void get_table_name(std::string &schema, std::string &table) const
Get schema and table name in system character set.
Definition: dict0dd.cc:7299
bool is_system_schema() const
Definition: dict0mem.h:1963
dict_foreign_set referenced_set
Definition: dict0mem.h:2197
unsigned n_def
Number of non-virtual columns defined so far.
Definition: dict0mem.h:2064
std::atomic< bool > stats_updated
true if statistics have been updated in the background and not yet collected by the optimizer
Definition: dict0mem.h:2243
uint16_t get_n_sys_cols() const
Gets the number of system columns in a table.
Definition: dict0mem.h:2654
std::atomic< os_once::state_t > mutex_created
Creation state of mutex.
Definition: dict0mem.h:1982
uint64_t autoinc_persisted
Autoinc counter value that has been persisted in redo logs or DDTableBuffer.
Definition: dict0mem.h:2377
bool is_encrypted() const
Check if the table is encrypted.
Definition: dict0mem.h:1932
bool has_instant_add_cols() const
check if table has INSTANT ADD columns.
Definition: dict0mem.h:2564
fts_t * fts
FTS specific state variables.
Definition: dict0mem.h:2397
std::atomic< std::chrono::system_clock::time_point > update_time
Timestamp of the last modification of this table.
Definition: dict0mem.h:2443
bool is_intrinsic() const
Determine whether the table is intrinsic.
Definition: dict0mem.h:2720
ib_mutex_t * autoinc_mutex
Mutex protecting the autoincrement counter.
Definition: dict0mem.h:2354
bool can_be_evicted
true if this table is expected to be kept in memory.
Definition: dict0mem.h:2091
ulong count_by_mode[LOCK_NUM]
count_by_mode[M] = number of locks in this->locks with lock->type_mode&LOCK_MODE_MASK == M.
Definition: dict0mem.h:2439
dict_v_col_t * v_cols
Array of virtual column descriptions.
Definition: dict0mem.h:2105
temp_prebuilt_vec * temp_prebuilt
multiple cursors can be active on this temporary table
Definition: dict0mem.h:2474
void set_upgraded_instant()
Set table to be upgraded table with INSTANT ADD columns in V1.
Definition: dict0mem.h:2571
mem_heap_t * heap
Memory heap.
Definition: dict0mem.h:1997
dict_index_t * fts_doc_id_index
The FTS_DOC_ID_INDEX, or NULL if no fulltext indexes exist.
Definition: dict0mem.h:2137
table_name_t trunc_name
Truncate name.
Definition: dict0mem.h:2003
unsigned stat_initialized
true if statistics have been calculated the first time after database startup or table creation.
Definition: dict0mem.h:2239
uint64_t sess_trx_id
trx_id counter for use by intrinsic table for getting trx-id.
Definition: dict0mem.h:2456
std::atomic< uint64_t > n_ref_count
Count of how many handles are opened to this table.
Definition: dict0mem.h:2421
unsigned n_v_cols
Number of virtual columns.
Definition: dict0mem.h:2084
bool in_dirty_dict_tables_list
This field is used to mark if a table is in the dirty_dict_tables_list.
Definition: dict0mem.h:2179
ib_mutex_t * stats_compute_mutex
Mutex protecting table and index statistics calculation process.
Definition: dict0mem.h:2235
std::chrono::steady_clock::time_point stats_last_recalc
Timestamp of last recalc of the stats.
Definition: dict0mem.h:2246
bool is_corrupted() const
Check whether the table is corrupted.
Definition: dict0mem.h:2579
std::atomic< os_once::state_t > stats_compute_mutex_created
Creation state of 'stats_compute_mutex'.
Definition: dict0mem.h:2232
ulint get_n_cols() const
Gets the number of all non-virtual columns (also system) in a table in the dictionary cache.
Definition: dict0mem.h:2663
const char * col_names
Column names packed in a character string "name1\0name2\0...nameN\0".
Definition: dict0mem.h:2121
table_name_t name
Table name.
Definition: dict0mem.h:2000
char * data_dir_path
NULL or the directory path specified by DATA DIRECTORY.
Definition: dict0mem.h:2006
const dict_index_t * first_index() const
Definition: dict0mem.h:2491
uint64_t get_ref_count() const
Get reference count.
Definition: dict0dict.ic:1035
lock_t * autoinc_lock
AUTOINC related members.
Definition: dict0mem.h:2347
uint32_t stat_persistent
Indicates whether the table uses persistent stats or not.
Definition: dict0mem.h:2263
uint32_t initial_col_count
Initial non-virtual column count.
Definition: dict0mem.h:2154
const char * v_col_names
Virtual column names.
Definition: dict0mem.h:2124
uint32_t current_col_count
Current non-virtual column count.
Definition: dict0mem.h:2157
unsigned big_rows
true if the maximum length of a single row exceeds BIG_ROW_SIZE.
Definition: dict0mem.h:2210
hash_node_t id_hash
Hash chain node.
Definition: dict0mem.h:2134
bool m_upgraded_instant
Set if table is upgraded instant table.
Definition: dict0mem.h:2163
bool has_instant_drop_cols() const
check if table has INSTANT DROP columns.
Definition: dict0mem.h:2568
uint64_t stat_n_rows
Approximate number of rows in the table.
Definition: dict0mem.h:2290
bool is_fts_aux() const
Determine if this is a FTS AUX table.
Definition: dict0mem.h:2705
uint32_t get_n_instant_drop_cols() const
Get number of columns dropped instantly.
Definition: dict0mem.h:2557
uint32_t current_row_version
Current row version in case columns are added/dropped INSTANTly.
Definition: dict0mem.h:2151
std::atomic< os_once::state_t > autoinc_mutex_created
Creation state of autoinc_mutex member.
Definition: dict0mem.h:2350
bool is_dd_table
true only for dictionary tables like mysql/tables, mysql/columns, mysql/tablespaces,...
Definition: dict0mem.h:2480
bool is_upgraded_instant() const
Checks if table is upgraded table with INSTANT ADD columns in V1.
Definition: dict0mem.h:2575
UT_LIST_NODE_T(dict_table_t) dirty_dict_tables
Node of the dirty table list of tables, which is protected by dict_persist->mutex.
std::atomic< os_once::state_t > stats_latch_created
Statistics for query optimization.
Definition: dict0mem.h:2216
ib_mutex_t * autoinc_persisted_mutex
Mutex protecting the persisted autoincrement counter.
Definition: dict0mem.h:2360
bool does_not_fit_in_memory
This field is used to specify in simulations tables which are so big that disk should be accessed.
Definition: dict0mem.h:2205
unsigned ddl_not_evictable
true if this table is not evictable(can_be_evicted) and this is because of DDL operation
Definition: dict0mem.h:2095
dict_col_t * cols
Array of column descriptions.
Definition: dict0mem.h:2102
space_id_t space
Space where the clustered index of the table is placed.
Definition: dict0mem.h:2013
Data structure for a virtual column in a table.
Definition: dict0mem.h:811
dict_v_idx_list * v_indexes
Virtual index list, and column position in the index, the allocated memory is not from table->heap,...
Definition: dict0mem.h:827
ulint v_pos
column pos in table
Definition: dict0mem.h:822
dict_col_t m_col
column structure
Definition: dict0mem.h:813
ulint num_base
number of base columns
Definition: dict0mem.h:819
dict_col_t ** base_col
array of base column ptr
Definition: dict0mem.h:816
Index information put in a list of virtual column structure.
Definition: dict0mem.h:799
ulint nth_field
position in this index
Definition: dict0mem.h:804
dict_index_t * index
active index on the column
Definition: dict0mem.h:801
Structure defines template related to virtual columns and their base columns.
Definition: dict0mem.h:1862
byte * default_rec
default column value if any
Definition: dict0mem.h:1885
ulint n_v_col
number of virtual columns
Definition: dict0mem.h:1867
std::string tb_name
table name
Definition: dict0mem.h:1876
ulint rec_len
MySQL record length.
Definition: dict0mem.h:1882
std::string share_name
share->table_name
Definition: dict0mem.h:1879
ulint n_col
number of regular columns
Definition: dict0mem.h:1864
mysql_row_templ_t ** vtempl
array of templates for virtual col and their base columns
Definition: dict0mem.h:1870
std::string db_name
table's database name
Definition: dict0mem.h:1873
Definition: data0type.h:498
Red black tree instance.
Definition: ut0rbt.h:72
Lock struct; protected by lock_sys latches.
Definition: lock0priv.h:137
The info structure stored at the beginning of a heap block.
Definition: mem0mem.h:302
Mini-transaction handle and buffer.
Definition: mtr0mtr.h:177
bool is_active() const
Definition: mtr0mtr.h:510
Definition: row0mysql.h:455
If key is fixed length key then cache the record offsets on first computation.
Definition: dict0mem.h:976
size_t nullable_cols
Number of NULLable columns among those for which offsets are cached.
Definition: dict0mem.h:981
const ulint * offsets
Holds reference to cached offsets for record.
Definition: dict0mem.h:978
Buffer for logging modifications during online index creation.
Definition: row0log.cc:185
Definition: gis0type.h:152
Definition: gis0type.h:160
The structure used in the spin lock implementation of a read-write lock.
Definition: sync0rw.h:362
Definition: plugin_ftparser.h:216
Table name wrapper for pretty-printing.
Definition: dict0mem.h:466
char * m_name
The name in internal representation.
Definition: dict0mem.h:468
Definition: trx0trx.h:675
Data structure to hold information about about how much space in an uncompressed page should be left ...
Definition: dict0mem.h:958
SysMutex * mutex
mutex protecting the info
Definition: dict0mem.h:959
ulint success
successful compression ops during current round
Definition: dict0mem.h:961
std::atomic< ulint > pad
number of bytes used as pad
Definition: dict0mem.h:960
ulint n_rounds
number of currently successful rounds
Definition: dict0mem.h:965
ulint failure
failed compression ops during current round
Definition: dict0mem.h:963
std::atomic< os_once::state_t > mutex_created
Creation state of mutex member.
Definition: dict0mem.h:968
The read-write lock (for threads, not for database transactions)
Transaction system global type definitions.
ib_id_t trx_id_t
Transaction identifier (DB_TRX_ID, DATA_TRX_ID)
Definition: trx0types.h:138
Definition: dtoa.cc:595
Version control for database, common definitions, and include files.
constexpr uint32_t UINT32_UNDEFINED
The 'undefined' value for a 32-bit unsigned integer.
Definition: univ.i:428
#define UNIV_LIKELY(cond)
Definition: univ.i:519
constexpr uint32_t UNIV_SQL_NULL
The following number as the length of a logical field means that the field has the SQL NULL as its va...
Definition: univ.i:463
constexpr uint16_t UINT16_UNDEFINED
The 'undefined' value for a 16-bit unsigned integer.
Definition: univ.i:431
unsigned long int ulint
Definition: univ.i:406
Utilities for byte operations.
#define ut_ad(EXPR)
Debug assertion.
Definition: ut0dbg.h:105
#define ut_ad_eq(LHS, RHS)
Debug-only assertion that LHS == RHS.
Definition: ut0dbg.h:115
#define ut_a(EXPR)
Abort execution if EXPR does not evaluate to nonzero.
Definition: ut0dbg.h:93
#define UT_LIST_GET_LEN(BASE)
Alternative macro to get the number of nodes in a two-way list, i.e., its length.
Definition: ut0lst.h:441
#define UT_LIST_GET_FIRST(BASE)
Gets the first node in a two-way list.
Definition: ut0lst.h:446
#define UT_LIST_GET_NEXT(NAME, N)
Gets the next node in a two-way list.
Definition: ut0lst.h:429
Memory primitives.
static int ut_strcmp(const char *str1, const char *str2)
Wrapper for strcmp(3).
#define mutex_own(M)
Checks that the current thread owns the mutex.
Definition: ut0mutex.h:165
#define mutex_exit(M)
Definition: ut0mutex.h:123
#define mutex_free(M)
Definition: ut0mutex.h:125
Dynamic memory allocation routines and custom allocators specifically crafted to support memory instr...
Random numbers and hashing.
unsigned long id[MAX_DEAD]
Definition: xcom_base.cc:510
int n
Definition: xcom_base.cc:509