MySQL 8.0.40
Source Code Documentation
fts0fts.h
Go to the documentation of this file.
1/*****************************************************************************
2
3Copyright (c) 2006, 2024, Oracle and/or its affiliates.
4
5This program is free software; you can redistribute it and/or modify it under
6the terms of the GNU General Public License, version 2.0, as published by the
7Free Software Foundation.
8
9This program is designed to work with certain software (including
10but not limited to OpenSSL) that is licensed under separate terms,
11as designated in a particular file or component or in included license
12documentation. The authors of MySQL hereby grant you an additional
13permission to link the program and your derivative works with the
14separately licensed software that they have either included with
15the program or referenced in the documentation.
16
17This program is distributed in the hope that it will be useful, but WITHOUT
18ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
19FOR A PARTICULAR PURPOSE. See the GNU General Public License, version 2.0,
20for more details.
21
22You should have received a copy of the GNU General Public License along with
23this program; if not, write to the Free Software Foundation, Inc.,
2451 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
25
26*****************************************************************************/
27
28/** @file include/fts0fts.h
29 Full text search header file
30
31 Created 2011/09/02 Sunny Bains
32 ***********************************************************************/
33
34#ifndef fts0fts_h
35#define fts0fts_h
36
37#include "ha_prototypes.h"
38
39#include "data0type.h"
40#include "data0types.h"
41#include "dict0types.h"
42#include "ft_global.h"
43#include "hash0hash.h"
44#include "mem0mem.h"
46#include "que0types.h"
47#include "rem0types.h"
48#include "row0types.h"
49#include "trx0types.h"
50#include "ut0rbt.h"
51#include "ut0vec.h"
52#include "ut0wqueue.h"
53
54/** "NULL" value of a document id. */
55#define FTS_NULL_DOC_ID 0
56
57/** FTS hidden column that is used to map to and from the row */
58#define FTS_DOC_ID_COL_NAME "FTS_DOC_ID"
59
60/** The name of the index created by FTS */
61#define FTS_DOC_ID_INDEX_NAME "FTS_DOC_ID_INDEX"
62
63#define FTS_DOC_ID_INDEX_NAME_LEN 16
64
65/** Doc ID is a 8 byte value */
66#define FTS_DOC_ID_LEN 8
67
68/** The number of fields to sort when we build FT index with
69FIC. Three fields are sort: (word, doc_id, position) */
70#define FTS_NUM_FIELDS_SORT 3
71
72/** Maximum number of rows in a table, smaller than which, we will
73optimize using a 4 byte Doc ID for FIC merge sort to reduce sort size */
74#define MAX_DOC_ID_OPT_VAL 1073741824
75
76/** Document id type. */
77typedef uint64_t doc_id_t;
78
79/** doc_id_t printf format */
80#define FTS_DOC_ID_FORMAT IB_ID_FMT
81
82/** Convert document id to the InnoDB (BIG ENDIAN) storage format. */
83#define fts_write_doc_id(d, s) mach_write_to_8(d, s)
84
85/** Read a document id to internal format. */
86#define fts_read_doc_id(s) mach_read_from_8(s)
87
88/** Bind the doc id to a variable */
89#define fts_bind_doc_id(i, n, v) pars_info_bind_int8_literal(i, n, v)
90
91/** Defines for FTS query mode, they have the same values as
92those defined in mysql file ft_global.h */
93#define FTS_NL 0
94#define FTS_BOOL 1
95#define FTS_SORTED 2
96#define FTS_EXPAND 4
97#define FTS_NO_RANKING 8
98#define FTS_PROXIMITY 16
99#define FTS_PHRASE 32
100#define FTS_OPT_RANKING 64
101
102#define FTS_INDEX_TABLE_IND_NAME "FTS_INDEX_TABLE_IND"
103#define FTS_COMMON_TABLE_IND_NAME "FTS_COMMON_TABLE_IND"
104
105/** The number of FTS index partitions for a fulltext index. */
106constexpr size_t FTS_NUM_AUX_INDEX = 6;
107
108/** The number of FTS AUX common table for a fulltext index. */
109constexpr size_t FTS_NUM_AUX_COMMON = 5;
110
111/** Threshold where our optimize thread automatically kicks in */
112#define FTS_OPTIMIZE_THRESHOLD 10000000
113
114/** Threshold to avoid exhausting of doc ids. Consecutive doc id difference
115should not exceed FTS_DOC_ID_MAX_STEP */
116#define FTS_DOC_ID_MAX_STEP 65535
117
118/** Maximum possible Fulltext word length */
119#define FTS_MAX_WORD_LEN HA_FT_MAXBYTELEN
120
121/** Maximum possible Fulltext word length (in characters) */
122#define FTS_MAX_WORD_LEN_IN_CHAR HA_FT_MAXCHARLEN
123
124/** Number of columns in FTS AUX Tables */
125#define FTS_DELETED_TABLE_NUM_COLS 1
126#define FTS_CONFIG_TABLE_NUM_COLS 2
127#define FTS_AUX_INDEX_TABLE_NUM_COLS 5
128
129/** DELETED_TABLE(doc_id BIGINT UNSIGNED) */
130#define FTS_DELETED_TABLE_COL_LEN 8
131/** CONFIG_TABLE(key CHAR(50), value CHAR(200)) */
132#define FTS_CONFIG_TABLE_KEY_COL_LEN 50
133#define FTS_CONFIG_TABLE_VALUE_COL_LEN 200
134
135#define FTS_INDEX_WORD_LEN FTS_MAX_WORD_LEN
136#define FTS_INDEX_FIRST_DOC_ID_LEN 8
137#define FTS_INDEX_LAST_DOC_ID_LEN 8
138#define FTS_INDEX_DOC_COUNT_LEN 4
139/* BLOB COLUMN, 0 means VARIABLE SIZE */
140#define FTS_INDEX_ILIST_LEN 0
141/* Maximum nested expression in fulltext binary search string */
142#define FTS_MAX_NESTED_EXP 31
143
144extern const char *FTS_PREFIX;
145extern const char *FTS_SUFFIX_BEING_DELETED;
146extern const char *FTS_SUFFIX_BEING_DELETED_CACHE;
147extern const char *FTS_SUFFIX_CONFIG;
148extern const char *FTS_SUFFIX_DELETED;
149extern const char *FTS_SUFFIX_DELETED_CACHE;
150
151extern const char *FTS_PREFIX_5_7;
152extern const char *FTS_SUFFIX_CONFIG_5_7;
153
154/** Variable specifying the number of word to optimize for each optimize table
155call */
156extern ulong fts_num_word_optimize;
157
158/** Variable specifying whether we do additional FTS diagnostic printout
159in the log */
160extern bool fts_enable_diag_print;
161
162/** FTS rank type, which will be between 0 .. 1 inclusive */
163typedef float fts_rank_t;
164
165/** Structure to manage FTS AUX table name and MDL during its drop */
167 /** AUX table name */
168 std::vector<char *> aux_name;
169};
170
171/** Type of a row during a transaction. FTS_NOTHING means the row can be
172forgotten from the FTS system's POV, FTS_INVALID is an internal value used
173to mark invalid states.
174
175NOTE: Do not change the order or value of these, fts_trx_row_get_new_state
176depends on them being exactly as they are. */
184
185/** The FTS table types. */
187 FTS_INDEX_TABLE, /*!< FTS auxiliary table that is
188 specific to a particular FTS index
189 on a table */
190
191 FTS_COMMON_TABLE, /*!< FTS auxiliary table that is common
192 for all FTS index on a table */
193
194 FTS_OBSOLETED_TABLE /*!< FTS obsoleted tables like DOC_ID,
195 ADDED, STOPWORDS */
197
198struct fts_doc_t;
199struct fts_cache_t;
200struct fts_token_t;
201struct fts_doc_ids_t;
202struct fts_index_cache_t;
203
204/** Initialize the "fts_table" for internal query into FTS auxiliary
205tables */
206#define FTS_INIT_FTS_TABLE(fts_table, m_suffix, m_type, m_table) \
207 do { \
208 (fts_table)->suffix = m_suffix; \
209 (fts_table)->type = m_type; \
210 (fts_table)->table_id = m_table->id; \
211 (fts_table)->parent = m_table->name.m_name; \
212 (fts_table)->table = m_table; \
213 } while (0);
214
215#define FTS_INIT_INDEX_TABLE(fts_table, m_suffix, m_type, m_index) \
216 do { \
217 (fts_table)->suffix = m_suffix; \
218 (fts_table)->type = m_type; \
219 (fts_table)->table_id = m_index->table->id; \
220 (fts_table)->parent = m_index->table->name.m_name; \
221 (fts_table)->table = m_index->table; \
222 (fts_table)->index_id = m_index->id; \
223 } while (0);
224
225/** Information about changes in a single transaction affecting
226the FTS system. */
227struct fts_trx_t {
228 trx_t *trx; /*!< InnoDB transaction */
229
230 ib_vector_t *savepoints; /*!< Active savepoints, must have at
231 least one element, the implied
232 savepoint */
233 ib_vector_t *last_stmt; /*!< last_stmt */
234
235 mem_heap_t *heap; /*!< heap */
236};
237
238/** Information required for transaction savepoint handling. */
240 char *name; /*!< First entry is always NULL, the
241 default instance. Otherwise the name
242 of the savepoint */
243
244 ib_rbt_t *tables; /*!< Modified FTS tables */
245};
246
247/** Information about changed rows in a transaction for a single table. */
249 dict_table_t *table; /*!< table */
250
251 fts_trx_t *fts_trx; /*!< link to parent */
252
253 ib_rbt_t *rows; /*!< rows changed; indexed by doc-id,
254 cells are fts_trx_row_t* */
255
256 fts_doc_ids_t *added_doc_ids; /*!< list of added doc ids (NULL until
257 the first addition) */
258
259 /*!< for adding doc ids */
261};
262
263/** Information about one changed row in a transaction. */
265 doc_id_t doc_id; /*!< Id of the ins/upd/del document */
266
267 fts_row_state state; /*!< state of the row */
268
269 ib_vector_t *fts_indexes; /*!< The indexes that are affected */
270};
271
272/** List of document ids that were added during a transaction. This
273list is passed on to a background 'Add' thread and OPTIMIZE, so it
274needs its own memory heap. */
276 ib_vector_t *doc_ids; /*!< document ids (each element is
277 of type doc_id_t). */
278
279 ib_alloc_t *self_heap; /*!< Allocator used to create an
280 instance of this type and the
281 doc_ids vector */
282};
283
284// FIXME: Get rid of this if possible.
285/** Since MySQL's character set support for Unicode is woefully inadequate
286(it supports basic operations like isalpha etc. only for 8-bit characters),
287we have to implement our own. We use UTF-16 without surrogate processing
288as our in-memory format. This typedef is a single such character. */
289typedef unsigned short ib_uc_t;
290
291/** An UTF-16 ro UTF-8 string. */
293 byte *f_str; /*!< string, not necessary terminated in
294 any way */
295 ulint f_len; /*!< Length of the string in bytes */
296 ulint f_n_char; /*!< Number of characters */
297};
298
299/** Query ranked doc ids. */
301 doc_id_t doc_id; /*!< Document id */
302
303 fts_rank_t rank; /*!< Rank is between 0 .. 1 */
304
305 byte *words; /*!< this contains the words
306 that were queried
307 and found in this document */
308 ulint words_len; /*!< words len */
309};
310
311/** Query result. */
313 ib_rbt_node_t *current; /*!< Current element */
314
315 ib_rbt_t *rankings_by_id; /*!< RB tree of type fts_ranking_t
316 indexed by doc id */
317 ib_rbt_t *rankings_by_rank; /*!< RB tree of type fts_ranking_t
318 indexed by rank */
319};
320
321/** This is used to generate the FTS auxiliary table name, we need the
322table id and the index id to generate the column specific FTS auxiliary
323table name. */
325 const char *parent; /*!< Parent table name, this is
326 required only for the database
327 name */
328
329 fts_table_type_t type; /*!< The auxiliary table type */
330
331 table_id_t table_id; /*!< The table id */
332
333 space_index_t index_id; /*!< The index id */
334
335 const char *suffix; /*!< The suffix of the fts auxiliary
336 table name, can be NULL, not used
337 everywhere (yet) */
338 const dict_table_t *table; /*!< Parent table */
339 CHARSET_INFO *charset; /*!< charset info if it is for FTS
340 index auxiliary table */
341};
342
344 BG_THREAD_STOP = 1, /*!< true if the FTS background thread
345 has finished reading the ADDED table,
346 meaning more items can be added to
347 the table. */
348
349 BG_THREAD_READY = 2, /*!< true if the FTS background thread
350 is ready */
351
352 ADD_THREAD_STARTED = 4, /*!< true if the FTS add thread
353 has started */
354
355 ADDED_TABLE_SYNCED = 8, /*!< true if the ADDED table record is
356 sync-ed after crash recovery */
357};
358
360
361/** The state of the FTS sub system. */
362class fts_t {
363 public:
364 /** fts_t constructor.
365 @param[in] table table with FTS indexes
366 @param[in,out] heap memory heap where 'this' is stored */
367 fts_t(dict_table_t *table, mem_heap_t *heap);
368
369 /** fts_t destructor. */
370 ~fts_t();
371
372 /** Mutex protecting bg_threads* and fts_add_wq. */
374
375 /** Number of background threads accessing this table. */
377
378 /** Status bit regarding fts running state. true if background
379 threads running should stop themselves. */
381
382 /** Work queue for scheduling jobs for the FTS 'Add' thread, or NULL
383 if the thread has not yet been created. Each work item is a
384 fts_trx_doc_ids_t*. */
386
387 /** FTS memory buffer for this table, or NULL if the table has no FTS
388 index. */
390
391 /** FTS doc id hidden column number in the CLUSTERED index. */
393
394 /** Vector of FTS indexes, this is mainly for caching purposes. */
396
397 /** Heap for fts_t allocation. */
399};
400
401struct fts_stopword_t;
402
403/** status bits for fts_stopword_t status field. */
404#define STOPWORD_NOT_INIT 0x1
405#define STOPWORD_OFF 0x2
406#define STOPWORD_FROM_DEFAULT 0x4
407#define STOPWORD_USER_TABLE 0x8
408
409extern const char *fts_default_stopword[];
410
411/** Variable specifying the maximum FTS cache size for each table */
412extern ulong fts_max_cache_size;
413
414/** Variable specifying the total memory allocated for FTS cache */
415extern ulong fts_max_total_cache_size;
416
417/** Variable specifying the FTS result cache limit for each query */
418extern ulong fts_result_cache_limit;
419
420/** Variable specifying the maximum FTS max token size */
421extern ulong fts_max_token_size;
422
423/** Variable specifying the minimum FTS max token size */
424extern ulong fts_min_token_size;
425
426/** Whether the total memory used for FTS cache is exhausted, and we will
427need a sync to free some memory */
428extern bool fts_need_sync;
429
430/** Variable specifying the table that has Fulltext index to display its
431content through information schema table */
432extern char *fts_internal_tbl_name;
433
434#define fts_que_graph_free(graph) \
435 do { \
436 que_graph_free(graph); \
437 } while (0)
438
439/** Create a FTS cache. */
441 dict_table_t *table); /*!< table owns the FTS cache */
442
443/** Create a FTS index cache.
444 @return Index Cache */
446 dict_table_t *table, /*!< in: table with FTS index */
447 dict_index_t *index); /*!< in: FTS index */
448
449/** Remove a FTS index cache
450@param[in] table table with FTS index
451@param[in] index FTS index */
453
454/** Get the next available document id. This function creates a new
455 transaction to generate the document id.
456 @return DB_SUCCESS if OK */
457dberr_t fts_get_next_doc_id(const dict_table_t *table, /*!< in: table */
458 doc_id_t *doc_id); /*!< out: new document id */
459/** Update the next and last Doc ID in the CONFIG table to be the input
460 "doc_id" value (+ 1). We would do so after each FTS index build or
461 table truncate */
463 trx_t *trx, /*!< in/out: transaction */
464 const dict_table_t *table, /*!< in: table */
465 const char *table_name, /*!< in: table name, or NULL */
466 doc_id_t doc_id); /*!< in: DOC ID to set */
467
468/** Create a new document id.
469@param[in] table Row is of this table.
470@param[in,out] row Add doc id value to this row. This is the current row
471that is being inserted.
472@param[in] heap Memory heap on which the doc_id object will be created.
473@return DB_SUCCESS if all went well else error */
475
476/** Create a new fts_doc_ids_t.
477 @return new fts_doc_ids_t. */
479
480/** Free a fts_doc_ids_t. */
481void fts_doc_ids_free(fts_doc_ids_t *doc_ids); /*!< in: doc_ids to free */
482
483/** Notify the FTS system about an operation on an FTS-indexed table.
484@param[in] trx Innodb transaction
485@param[in] table Table
486@param[in] doc_id Doc id
487@param[in] state State of the row
488@param[in] fts_indexes Fts indexes affected (null=all) */
489void fts_trx_add_op(trx_t *trx, dict_table_t *table, doc_id_t doc_id,
490 fts_row_state state, ib_vector_t *fts_indexes);
491
492/** Free an FTS trx. */
493void fts_trx_free(fts_trx_t *fts_trx); /*!< in, own: FTS trx */
494
495/** Check if common tables already exist
496@param[in] table table with fts index
497@return true on success, false on failure */
499
500/** Creates the common auxiliary tables needed for supporting an FTS index
501on the given table. row_mysql_lock_data_dictionary must have been called
502before this.
503The following tables are created.
504CREATE TABLE $FTS_PREFIX_DELETED
505 (doc_id BIGINT UNSIGNED, UNIQUE CLUSTERED INDEX on doc_id)
506CREATE TABLE $FTS_PREFIX_DELETED_CACHE
507 (doc_id BIGINT UNSIGNED, UNIQUE CLUSTERED INDEX on doc_id)
508CREATE TABLE $FTS_PREFIX_BEING_DELETED
509 (doc_id BIGINT UNSIGNED, UNIQUE CLUSTERED INDEX on doc_id)
510CREATE TABLE $FTS_PREFIX_BEING_DELETED_CACHE
511 (doc_id BIGINT UNSIGNED, UNIQUE CLUSTERED INDEX on doc_id)
512CREATE TABLE $FTS_PREFIX_CONFIG
513 (key CHAR(50), value CHAR(200), UNIQUE CLUSTERED INDEX on key)
514@param[in,out] trx transaction
515@param[in] table table with FTS index
516@param[in] name table name normalized
517@param[in] skip_doc_id_index Skip index on doc id
518@return DB_SUCCESS if succeed */
519[[nodiscard]] dberr_t fts_create_common_tables(trx_t *trx,
520 const dict_table_t *table,
521 const char *name,
522 bool skip_doc_id_index);
523
524/** Creates the column specific ancillary tables needed for supporting an
525FTS index on the given table. row_mysql_lock_data_dictionary must have
526been called before this.
527
528All FTS AUX Index tables have the following schema.
529CREATE TABLE $FTS_PREFIX_INDEX_[1-6](
530 word VARCHAR(FTS_MAX_WORD_LEN),
531 first_doc_id INT NOT NULL,
532 last_doc_id UNSIGNED NOT NULL,
533 doc_count UNSIGNED INT NOT NULL,
534 ilist VARBINARY NOT NULL,
535 UNIQUE CLUSTERED INDEX ON (word, first_doc_id))
536@param[in,out] trx transaction
537@param[in] index index instance
538@return DB_SUCCESS or error code */
539[[nodiscard]] dberr_t fts_create_index_tables(trx_t *trx, dict_index_t *index);
540
541/** Create auxiliary index tables for an FTS index.
542@param[in,out] trx transaction
543@param[in] index the index instance
544@param[in] table_name table name
545@param[in] table_id the table id
546@return DB_SUCCESS or error code */
547[[nodiscard]] dberr_t fts_create_index_tables_low(trx_t *trx,
548 dict_index_t *index,
549 const char *table_name,
550 table_id_t table_id);
551
552/** Add the FTS document id hidden column.
553@param[in,out] table Table with FTS index
554@param[in] heap Temporary memory heap, or NULL */
556
557/** Drops the ancillary tables needed for supporting an FTS index on a
558given table. row_mysql_lock_data_dictionary must have been called before
559this.
560@param[in,out] trx transaction
561@param[in] table table has the fts index
562@param[in,out] aux_vec fts aux table name vector
563@return DB_SUCCESS or error code */
565 aux_name_vec_t *aux_vec);
566
567/** Lock all FTS AUX tables (for dropping table)
568@param[in] thd thread locking the AUX table
569@param[in] table table has the fts index
570@return DB_SUCCESS or error code */
572
573/** Drop FTS AUX table DD table objects in vector
574@param[in] aux_vec aux table name vector
575@param[in] file_per_table whether file per table
576@return true on success, false on failure. */
577bool fts_drop_dd_tables(const aux_name_vec_t *aux_vec, bool file_per_table);
578
579/** Free FTS AUX table names in vector
580@param[in] aux_vec aux table name vector
581*/
583
584/** The given transaction is about to be committed; do whatever is necessary
585 from the FTS system's POV.
586 @return DB_SUCCESS or error code */
587[[nodiscard]] dberr_t fts_commit(trx_t *trx); /*!< in: transaction */
588
589/** FTS Query entry point.
590@param[in] trx transaction
591@param[in] index fts index to search
592@param[in] flags FTS search mode
593@param[in] query_str FTS query
594@param[in] query_len FTS query string len in bytes
595@param[in,out] result result doc ids
596@param[in] limit limit value
597@return DB_SUCCESS if successful otherwise error code */
598[[nodiscard]] dberr_t fts_query(trx_t *trx, dict_index_t *index, uint flags,
599 const byte *query_str, ulint query_len,
600 fts_result_t **result, ulonglong limit);
601
602/** Retrieve the FTS Relevance Ranking result for doc with doc_id
603 @return the relevance ranking value. */
605 fts_result_t *result, /*!< in: FTS result structure */
606 doc_id_t doc_id); /*!< in: the interested document
607 doc_id */
608
609/** FTS Query sort result, returned by fts_query() on fts_ranking_t::rank. */
611 instance to sort.*/
612
613/** FTS Query free result, returned by fts_query(). */
614void fts_query_free_result(fts_result_t *result); /*!< in: result instance
615 to free.*/
616
617/** Extract the doc id from the FTS hidden column. */
618doc_id_t fts_get_doc_id_from_row(dict_table_t *table, /*!< in: table */
619 dtuple_t *row); /*!< in: row whose FTS doc id
620 we want to extract.*/
621
622/** Extract the doc id from the record that belongs to index.
623@param[in] table table
624@param[in] rec record contains FTS_DOC_ID
625@param[in] index index of rec
626@param[in] heap heap memory
627@return doc id that was extracted from rec */
629 const dict_index_t *index, mem_heap_t *heap);
630
631/** Add new fts doc id to the update vector.
632@param[in] table the table that contains the FTS index.
633@param[in,out] ufield the fts doc id field in the update vector.
634 No new memory is allocated for this in this
635 function.
636@param[in,out] next_doc_id the fts doc id that has been added to the
637 update vector. If 0, a new fts doc id is
638 automatically generated. The memory provided
639 for this argument will be used by the update
640 vector. Ensure that the life time of this
641 memory matches that of the update vector.
642@return the fts doc id used in the update vector */
644 doc_id_t *next_doc_id);
645
646/** FTS initialize. */
647void fts_startup(void);
648
649#if 0 // TODO: Enable this in WL#6608
650/******************************************************************//**
651Signal FTS threads to initiate shutdown. */
652void
653fts_start_shutdown(
654 dict_table_t* table, /*!< in: table with FTS
655 indexes */
656 fts_t* fts); /*!< in: fts instance to
657 shutdown */
658
659/******************************************************************//**
660Wait for FTS threads to shutdown. */
661void
662fts_shutdown(
663 dict_table_t* table, /*!< in: table with FTS
664 indexes */
665 fts_t* fts); /*!< in: fts instance to
666 shutdown */
667#endif
668
669/** Create an instance of fts_t.
670 @return instance of fts_t */
671fts_t *fts_create(dict_table_t *table); /*!< out: table with FTS
672 indexes */
673
674/** Free the FTS resources. */
675void fts_free(dict_table_t *table); /*!< in/out: table with
676 FTS indexes */
677
678/** Run OPTIMIZE on the given table.
679 @return DB_SUCCESS if all OK */
680dberr_t fts_optimize_table(dict_table_t *table); /*!< in: table to optimiza */
681
682/** Startup the optimize thread and create the work queue. */
683void fts_optimize_init(void);
684
685/** Since we do a horizontal split on the index table, we need to drop
686all the split tables.
687@param[in] trx transaction
688@param[in] index fts index
689@param[out] aux_vec dropped table names vector
690@return DB_SUCCESS or error code */
692 aux_name_vec_t *aux_vec);
693
694/** Empty all common talbes.
695@param[in,out] trx transaction
696@param[in] table dict table
697@return DB_SUCCESS or error code. */
699
700/** Remove the table from the OPTIMIZER's list. We do wait for
701 acknowledgement from the consumer of the message. */
702void fts_optimize_remove_table(dict_table_t *table); /*!< in: table to remove */
703
704/** Shutdown fts optimize thread. */
706
707/** Send sync fts cache for the table.
708@param[in] table table to sync */
710
711/** Take a FTS savepoint.
712@param[in] fts_trx Fts transaction
713@param[in] name Savepoint name */
714void fts_savepoint_take(fts_trx_t *fts_trx, const char *name);
715
716/** Refresh last statement savepoint. */
717void fts_savepoint_laststmt_refresh(trx_t *trx); /*!< in: transaction */
718
719/** Release the savepoint data identified by name. */
720void fts_savepoint_release(trx_t *trx, /*!< in: transaction */
721 const char *name); /*!< in: savepoint name */
722
723/** Clear cache.
724@param[in,out] cache fts cache */
725void fts_cache_clear(fts_cache_t *cache);
726
727/** Initialize things in cache. */
728void fts_cache_init(fts_cache_t *cache); /*!< in: cache */
729
730/** Rollback to and including savepoint identified by name. */
731void fts_savepoint_rollback(trx_t *trx, /*!< in: transaction */
732 const char *name); /*!< in: savepoint name */
733
734/** Rollback to and including savepoint identified by name. */
735void fts_savepoint_rollback_last_stmt(trx_t *trx); /*!< in: transaction */
736
737/* Get parent table name if it's a fts aux table
738@param[in] aux_table_name aux table name
739@param[in] aux_table_len aux table length
740@return parent table name, or NULL */
741char *fts_get_parent_table_name(const char *aux_table_name,
742 ulint aux_table_len);
743
744/** Run SYNC on the table, i.e., write out data from the cache to the
745FTS auxiliary INDEX table and clear the cache at the end.
746@param[in,out] table fts table
747@param[in] unlock_cache whether unlock cache when write node
748@param[in] wait whether wait for existing sync to finish
749@param[in] has_dict whether has dict operation lock
750@return DB_SUCCESS on success, error code on failure. */
751dberr_t fts_sync_table(dict_table_t *table, bool unlock_cache, bool wait,
752 bool has_dict);
753
754/** Create an FTS index cache. */
755CHARSET_INFO *fts_index_get_charset(dict_index_t *index); /*!< in: FTS index */
756
757/** Get the initial Doc ID by consulting the CONFIG table
758 @return initial Doc ID */
759doc_id_t fts_init_doc_id(const dict_table_t *table); /*!< in: table */
760
761/** Compare two character string according to their charset.
762@param[in] cs Character set
763@param[in] p1 Key
764@param[in] p2 Node */
765extern int innobase_fts_text_cmp(const void *cs, const void *p1,
766 const void *p2);
767
768/** Makes all characters in a string lower case.
769@param[in] cs Character set
770@param[in] src String to put in lower case
771@param[in] src_len Input string length
772@param[in] dst Buffer for result string
773@param[in] dst_len Buffer size */
774extern size_t innobase_fts_casedn_str(CHARSET_INFO *cs, char *src,
775 size_t src_len, char *dst,
776 size_t dst_len);
777
778/** Compare two character string according to their charset.
779@param[in] cs Character set
780@param[in] p1 Key
781@param[in] p2 Node */
782extern int innobase_fts_text_cmp_prefix(const void *cs, const void *p1,
783 const void *p2);
784
785/** Get the next token from the given string and store it in *token. */
787 CHARSET_INFO *charset, /*!< in: Character set */
788 const byte *start, /*!< in: start of text */
789 const byte *end, /*!< in: one character past
790 end of text */
791 fts_string_t *token); /*!< out: token's text */
792
793/** Drop dd table & tablespace for fts aux table
794@param[in] name table name
795@param[in] file_per_table flag whether use file per table
796@return true on success, false on failure. */
797bool innobase_fts_drop_dd_table(const char *name, bool file_per_table);
798
799/** Get token char size by charset
800 @return the number of token char size */
801ulint fts_get_token_size(const CHARSET_INFO *cs, /*!< in: Character set */
802 const char *token, /*!< in: token */
803 ulint len); /*!< in: token length */
804
805/** FULLTEXT tokenizer internal in MYSQL_FTPARSER_SIMPLE_MODE
806 @return 0 if tokenize successfully */
808 MYSQL_FTPARSER_PARAM *param, /*!< in: parser parameter */
809 char *doc, /*!< in: document to tokenize */
810 int len); /*!< in: document length */
811
812/** Fetch COUNT(*) from specified table.
813 @return the number of rows in the table */
814ulint fts_get_rows_count(fts_table_t *fts_table); /*!< in: fts table to read */
815
816/** Get maximum Doc ID in a table if index "FTS_DOC_ID_INDEX" exists
817 @return max Doc ID or 0 if index "FTS_DOC_ID_INDEX" does not exist */
818doc_id_t fts_get_max_doc_id(dict_table_t *table); /*!< in: user table */
819
820/** Check whether user supplied stopword table exists and is of
821 the right format.
822 @return the stopword column charset if qualifies */
824 const char *stopword_table_name); /*!< in: Stopword table
825 name */
826/** This function loads specified stopword into FTS cache
827 @return true if success */
829 const dict_table_t *table, /*!< in: Table with FTS */
830 trx_t *trx, /*!< in: Transaction */
831 const char *global_stopword_table, /*!< in: Global stopword table
832 name */
833 const char *session_stopword_table, /*!< in: Session stopword table
834 name */
835 bool stopword_is_on, /*!< in: Whether stopword
836 option is turned on/off */
837 bool reload); /*!< in: Whether it is during
838 reload of FTS table */
839
840/** Read the rows from the FTS index
841 @return DB_SUCCESS if OK */
842dberr_t fts_table_fetch_doc_ids(trx_t *trx, /*!< in: transaction */
843 fts_table_t *fts_table, /*!< in: aux table */
844 fts_doc_ids_t *doc_ids); /*!< in: For collecting
845 doc ids */
846/** This function brings FTS index in sync when FTS index is first
847 used. There are documents that have not yet sync-ed to auxiliary
848 tables from last server abnormally shutdown, we will need to bring
849 such document into FTS cache before any further operations
850 @return true if all OK */
851bool fts_init_index(dict_table_t *table, /*!< in: Table with FTS */
852 bool has_cache_lock); /*!< in: Whether we already
853 have cache lock */
854/** Add a newly create index in FTS cache */
855void fts_add_index(dict_index_t *index, /*!< FTS index to be added */
856 dict_table_t *table); /*!< table */
857
858/** Drop auxiliary tables related to an FTS index
859@param[in] table Table where indexes are dropped
860@param[in] index Index to be dropped
861@param[in] trx Transaction for the drop
862@param[in,out] aux_vec Aux table name vector
863@param[in] adding_another Another FTS index is to be added as part
864 of the same transaction
865@return DB_SUCCESS or error number */
867 aux_name_vec_t *aux_vec, bool adding_another = false);
868
869/** Rename auxiliary tables for all fts index for a table
870 @return DB_SUCCESS or error code */
871dberr_t fts_rename_aux_tables(dict_table_t *table, /*!< in: user Table */
872 const char *new_name, /*!< in: new table name */
873 trx_t *trx, /*!< in: transaction */
874 bool replay); /*!< Whether in replay
875 stage */
876
877/** Check indexes in the fts->indexes is also present in index cache and
878 table->indexes list
879 @return true if all indexes match */
881 dict_table_t *table); /*!< in: Table where indexes are dropped */
882
883/** Fetch the document from tuple, tokenize the text data and
884insert the text data into fts auxiliary table and
885its cache. Moreover this tuple fields doesn't contain any information
886about externally stored field. This tuple contains data directly
887converted from mysql.
888@param[in] ftt FTS transaction table
889@param[in] doc_id doc id
890@param[in] tuple tuple from where data can be retrieved
891 and tuple should be arranged in table
892 schema order. */
894 const dtuple_t *tuple);
895
896/** Create an FTS trx.
897@param[in,out] trx InnoDB Transaction
898@return FTS transaction. */
900
901/** For storing table info when checking for orphaned tables. */
903 /** Table id */
905
906 /** Parent table id */
908
909 /** Table FT index id */
911
912 /** Name of the table */
913 char *name;
914
915 /** FTS table type */
917};
918
919/** Check if a table is an FTS auxiliary table name.
920@param[out] table FTS table info
921@param[in] name Table name
922@param[in] len Length of table name
923@return true if the name matches an auxiliary table name pattern */
924bool fts_is_aux_table_name(fts_aux_table_t *table, const char *name, ulint len);
925
926/** Freeze all auiliary tables to be not evictable if exist, with dict_mutex
927held
928@param[in] table InnoDB table object */
929void fts_freeze_aux_tables(const dict_table_t *table);
930
931/** Allow all the auxiliary tables of specified base table to be evictable
932if they exist, if not exist just ignore
933@param[in] table InnoDB table object
934@param[in] dict_locked True if we have dict_sys mutex */
935void fts_detach_aux_tables(const dict_table_t *table, bool dict_locked);
936
937/** Update DD system table for auxiliary common tables for an FTS index.
938@param[in] table dict table instance
939@return true on success, false on failure */
941
942/** Check if a table has FTS index needs to have its auxiliary index
943tables' metadata updated in DD
944@param[in,out] table table to check
945@return DB_SUCCESS or error code */
947
948/** Upgrade FTS AUX Tables. The FTS common and aux tables are
949renamed because they have table_id in their name. We move table_ids
950by DICT_MAX_DD_TABLES offset. Aux tables are registered into DD
951after rename.
952@param[in] table InnoDB table object
953@return DB_SUCCESS or error code */
955
956/** Rename FTS AUX tablespace name from 8.0 format to 5.7 format.
957This will be done on upgrade failure
958@param[in] table parent table
959@param[in] rollback rollback the rename from 8.0 to 5.7
960 if true, rename to 5.7 format
961 if false, mark the table as evictable
962@return DB_SUCCESS on success, DB_ERROR on error */
964
965#endif
For each client connection we create a separate thread with THD serving as a thread/connection descri...
Definition: sql_lexer_thd.h:34
The state of the FTS sub system.
Definition: fts0fts.h:362
fts_cache_t * cache
FTS memory buffer for this table, or NULL if the table has no FTS index.
Definition: fts0fts.h:389
ulint bg_threads
Number of background threads accessing this table.
Definition: fts0fts.h:376
mem_heap_t * fts_heap
Heap for fts_t allocation.
Definition: fts0fts.h:398
~fts_t()
fts_t destructor.
Definition: fts0fts.cc:5442
ib_mutex_t bg_threads_mutex
Mutex protecting bg_threads* and fts_add_wq.
Definition: fts0fts.h:373
ulint doc_col
FTS doc id hidden column number in the CLUSTERED index.
Definition: fts0fts.h:392
ib_wqueue_t * add_wq
Work queue for scheduling jobs for the FTS 'Add' thread, or NULL if the thread has not yet been creat...
Definition: fts0fts.h:385
ulint fts_status
Status bit regarding fts running state.
Definition: fts0fts.h:380
fts_t(dict_table_t *table, mem_heap_t *heap)
fts_t constructor.
Definition: fts0fts.cc:5423
ib_vector_t * indexes
Vector of FTS indexes, this is mainly for caching purposes.
Definition: fts0fts.h:395
Data types.
Some type definitions.
dberr_t
Definition: db0err.h:39
Data dictionary global types.
ib_id_t space_index_t
Index identifier (unique within a tablespace).
Definition: dict0types.h:234
ib_id_t table_id_t
Table or partition identifier (unique within an InnoDB instance).
Definition: dict0types.h:232
Some definitions for full-text indices.
size_t innobase_fts_casedn_str(CHARSET_INFO *cs, char *src, size_t src_len, char *dst, size_t dst_len)
Makes all characters in a string lower case.
Definition: ha_innodb.cc:7807
const char * FTS_SUFFIX_CONFIG_5_7
Definition: fts0fts.cc:148
fts_trx_t * fts_trx_create(trx_t *trx)
Create an FTS trx.
Definition: fts0fts.cc:2481
dberr_t fts_create_index_tables(trx_t *trx, dict_index_t *index)
Creates the column specific ancillary tables needed for supporting an FTS index on the given table.
Definition: fts0fts.cc:2335
int fts_tokenize_document_internal(MYSQL_FTPARSER_PARAM *param, char *doc, int len)
FULLTEXT tokenizer internal in MYSQL_FTPARSER_SIMPLE_MODE.
Definition: fts0fts.cc:4717
dberr_t fts_create_doc_id(dict_table_t *table, dtuple_t *row, mem_heap_t *heap)
Create a new document id.
Definition: fts0fts.cc:3160
uint64_t doc_id_t
Document id type.
Definition: fts0fts.h:77
float fts_retrieve_ranking(fts_result_t *result, doc_id_t doc_id)
Retrieve the FTS Relevance Ranking result for doc with doc_id.
Definition: fts0que.cc:3306
void fts_query_sort_result_on_rank(fts_result_t *result)
FTS Query sort result, returned by fts_query() on fts_ranking_t::rank.
Definition: fts0que.cc:3839
void fts_startup(void)
FTS initialize.
void fts_optimize_request_sync_table(dict_table_t *table)
Send sync fts cache for the table.
Definition: fts0opt.cc:2555
dberr_t fts_upgrade_aux_tables(dict_table_t *table)
Upgrade FTS AUX Tables.
Definition: fts0fts.cc:6374
void fts_optimize_shutdown()
Shutdown fts optimize thread.
Definition: fts0opt.cc:3008
dberr_t fts_create_index_dd_tables(dict_table_t *table)
Check if a table has FTS index needs to have its auxiliary index tables' metadata updated in DD.
Definition: fts0fts.cc:2250
fts_doc_ids_t * fts_doc_ids_create(void)
Create a new fts_doc_ids_t.
Definition: fts0fts.cc:3006
void fts_add_doc_id_column(dict_table_t *table, mem_heap_t *heap)
Add the FTS document id hidden column.
Definition: fts0fts.cc:5359
const char * FTS_SUFFIX_BEING_DELETED_CACHE
Definition: fts0fts.cc:138
doc_id_t fts_update_doc_id(dict_table_t *table, upd_field_t *ufield, doc_id_t *next_doc_id)
Add new fts doc id to the update vector.
Definition: fts0fts.cc:5381
ulong fts_result_cache_limit
Variable specifying the FTS result cache limit for each query.
Definition: fts0fts.cc:85
void fts_add_doc_from_tuple(fts_trx_table_t *ftt, doc_id_t doc_id, const dtuple_t *tuple)
Fetch the document from tuple, tokenize the text data and insert the text data into fts auxiliary tab...
Definition: fts0fts.cc:3522
const char * fts_default_stopword[]
InnoDB default stopword list: There are different versions of stopwords, the stop words listed below ...
Definition: fts0fts.cc:119
dberr_t fts_get_next_doc_id(const dict_table_t *table, doc_id_t *doc_id)
Get the next available document id.
Definition: fts0fts.cc:2770
fts_index_cache_t * fts_cache_index_cache_create(dict_table_t *table, dict_index_t *index)
Create a FTS index cache.
Definition: fts0fts.cc:822
dberr_t fts_query(trx_t *trx, dict_index_t *index, uint flags, const byte *query_str, ulint query_len, fts_result_t **result, ulonglong limit)
FTS Query entry point.
Definition: fts0que.cc:3608
void fts_savepoint_rollback(trx_t *trx, const char *name)
Rollback to and including savepoint identified by name.
Definition: fts0fts.cc:5725
bool fts_drop_dd_tables(const aux_name_vec_t *aux_vec, bool file_per_table)
Drop FTS AUX table DD table objects in vector.
Definition: fts0fts.cc:1240
bool fts_check_common_tables_exist(const dict_table_t *table)
Check if common tables already exist.
Definition: fts0fts.cc:1869
doc_id_t fts_get_max_doc_id(dict_table_t *table)
Get maximum Doc ID in a table if index "FTS_DOC_ID_INDEX" exists.
Definition: fts0fts.cc:3776
void fts_add_index(dict_index_t *index, dict_table_t *table)
Add a newly create index in FTS cache.
Definition: fts0fts.cc:579
char * fts_internal_tbl_name
Variable specifying the table that has Fulltext index to display its content through information sche...
Definition: fts0fts.cc:111
const char * FTS_SUFFIX_CONFIG
Definition: fts0fts.cc:139
void fts_savepoint_take(fts_trx_t *fts_trx, const char *name)
Take a FTS savepoint.
Definition: fts0fts.cc:5541
enum fts_status fts_status_t
Definition: fts0fts.h:359
void fts_cache_index_cache_remove(dict_table_t *table, dict_index_t *index)
Remove a FTS index cache.
Definition: fts0fts.cc:866
void fts_optimize_init(void)
Startup the optimize thread and create the work queue.
Definition: fts0opt.cc:2991
void fts_trx_free(fts_trx_t *fts_trx)
Free an FTS trx.
Definition: fts0fts.cc:5146
void fts_update_next_doc_id(trx_t *trx, const dict_table_t *table, const char *table_name, doc_id_t doc_id)
Update the next and last Doc ID in the CONFIG table to be the input "doc_id" value (+ 1).
Definition: fts0fts.cc:2753
dberr_t fts_optimize_table(dict_table_t *table)
Run OPTIMIZE on the given table.
Definition: fts0opt.cc:2375
ulong fts_max_cache_size
Variable specifying the maximum FTS cache size for each table.
Definition: fts0fts.cc:74
void fts_free_aux_names(aux_name_vec_t *aux_vec)
Free FTS AUX table names in vector.
Definition: fts0fts.cc:1262
void fts_savepoint_release(trx_t *trx, const char *name)
Release the savepoint data identified by name.
Definition: fts0fts.cc:5587
doc_id_t fts_init_doc_id(const dict_table_t *table)
Get the initial Doc ID by consulting the CONFIG table.
Definition: fts0fts.cc:4919
dberr_t fts_sync_table(dict_table_t *table, bool unlock_cache, bool wait, bool has_dict)
Run SYNC on the table, i.e., write out data from the cache to the FTS auxiliary INDEX table and clear...
Definition: fts0fts.cc:4484
fts_t * fts_create(dict_table_t *table)
Create an instance of fts_t.
Definition: fts0fts.cc:5459
ulong fts_max_token_size
Variable specifying the maximum FTS max token size.
Definition: fts0fts.cc:88
void fts_doc_ids_free(fts_doc_ids_t *doc_ids)
Free a fts_doc_ids_t.
Definition: fts0fts.cc:3022
dberr_t fts_drop_index(dict_table_t *table, dict_index_t *index, trx_t *trx, aux_name_vec_t *aux_vec, bool adding_another=false)
Drop auxiliary tables related to an FTS index.
Definition: fts0fts.cc:709
fts_table_type_t
The FTS table types.
Definition: fts0fts.h:186
@ FTS_INDEX_TABLE
FTS auxiliary table that is specific to a particular FTS index on a table.
Definition: fts0fts.h:187
@ FTS_OBSOLETED_TABLE
FTS obsoleted tables like DOC_ID, ADDED, STOPWORDS.
Definition: fts0fts.h:194
@ FTS_COMMON_TABLE
FTS auxiliary table that is common for all FTS index on a table.
Definition: fts0fts.h:191
bool innobase_fts_drop_dd_table(const char *name, bool file_per_table)
Drop dd table & tablespace for fts aux table.
bool fts_load_stopword(const dict_table_t *table, trx_t *trx, const char *global_stopword_table, const char *session_stopword_table, bool stopword_is_on, bool reload)
This function loads specified stopword into FTS cache.
Definition: fts0fts.cc:5974
int innobase_fts_text_cmp_prefix(const void *cs, const void *p1, const void *p2)
Compare two character string according to their charset.
Definition: ha_innodb.cc:7786
void fts_cache_init(fts_cache_t *cache)
Initialize things in cache.
Definition: fts0fts.cc:497
dberr_t fts_create_index_tables_low(trx_t *trx, dict_index_t *index, const char *table_name, table_id_t table_id)
Create auxiliary index tables for an FTS index.
Definition: fts0fts.cc:2272
int innobase_fts_text_cmp(const void *cs, const void *p1, const void *p2)
Compare two character string according to their charset.
Definition: ha_innodb.cc:7713
doc_id_t fts_get_doc_id_from_row(dict_table_t *table, dtuple_t *row)
Extract the doc id from the FTS hidden column.
Definition: fts0fts.cc:5185
bool fts_check_cached_index(dict_table_t *table)
Check indexes in the fts->indexes is also present in index cache and table->indexes list.
Definition: fts0fts.cc:672
dberr_t fts_drop_tables(trx_t *trx, dict_table_t *table, aux_name_vec_t *aux_vec)
Drops the ancillary tables needed for supporting an FTS index on a given table.
Definition: fts0fts.cc:1647
doc_id_t fts_get_doc_id_from_rec(dict_table_t *table, const rec_t *rec, const dict_index_t *index, mem_heap_t *heap)
Extract the doc id from the record that belongs to index.
Definition: fts0fts.cc:5210
bool fts_init_index(dict_table_t *table, bool has_cache_lock)
This function brings FTS index in sync when FTS index is first used.
Definition: fts0fts.cc:6224
bool fts_create_common_dd_tables(const dict_table_t *table)
Update DD system table for auxiliary common tables for an FTS index.
Definition: fts0fts.cc:2176
ulint fts_get_rows_count(fts_table_t *fts_table)
Fetch COUNT(*) from specified table.
Definition: fts0fts.cc:4985
bool fts_need_sync
Whether the total memory used for FTS cache is exhausted, and we will need a sync to free some memory...
Definition: fts0fts.cc:78
const char * FTS_SUFFIX_BEING_DELETED
Definition: fts0fts.cc:137
bool fts_enable_diag_print
Variable specifying whether we do additional FTS diagnostic printout in the log.
Definition: fts0opt.cc:244
dberr_t fts_drop_index_tables(trx_t *trx, dict_index_t *index, aux_name_vec_t *aux_vec)
Since we do a horizontal split on the index table, we need to drop all the split tables.
Definition: fts0fts.cc:1486
dberr_t fts_rename_aux_tables(dict_table_t *table, const char *new_name, trx_t *trx, bool replay)
Rename auxiliary tables for all fts index for a table.
Definition: fts0fts.cc:1389
constexpr size_t FTS_NUM_AUX_INDEX
The number of FTS index partitions for a fulltext index.
Definition: fts0fts.h:106
void fts_detach_aux_tables(const dict_table_t *table, bool dict_locked)
Allow all the auxiliary tables of specified base table to be evictable if they exist,...
Definition: fts0fts.cc:2111
const char * FTS_PREFIX
FTS auxiliary table prefix that are common to all FT indexes.
Definition: fts0fts.cc:127
void fts_optimize_remove_table(dict_table_t *table)
Remove the table from the OPTIMIZER's list.
Definition: fts0opt.cc:2525
dberr_t fts_create_common_tables(trx_t *trx, const dict_table_t *table, const char *name, bool skip_doc_id_index)
Creates the common auxiliary tables needed for supporting an FTS index on the given table.
Definition: fts0fts.cc:1917
ulong fts_min_token_size
Variable specifying the minimum FTS max token size.
Definition: fts0fts.cc:91
CHARSET_INFO * fts_index_get_charset(dict_index_t *index)
Create an FTS index cache.
Definition: fts0fts.cc:787
fts_cache_t * fts_cache_create(dict_table_t *table)
Create a FTS cache.
Definition: fts0fts.cc:526
fts_status
Definition: fts0fts.h:343
@ BG_THREAD_STOP
true if the FTS background thread has finished reading the ADDED table, meaning more items can be add...
Definition: fts0fts.h:344
@ BG_THREAD_READY
true if the FTS background thread is ready
Definition: fts0fts.h:349
@ ADDED_TABLE_SYNCED
true if the ADDED table record is sync-ed after crash recovery
Definition: fts0fts.h:355
@ ADD_THREAD_STARTED
true if the FTS add thread has started
Definition: fts0fts.h:352
CHARSET_INFO * fts_valid_stopword_table(const char *stopword_table_name)
Check whether user supplied stopword table exists and is of the right format.
Definition: fts0fts.cc:5913
dberr_t fts_upgrade_rename(const dict_table_t *table, bool rollback)
Rename FTS AUX tablespace name from 8.0 format to 5.7 format.
Definition: fts0fts.cc:6478
dberr_t fts_lock_all_aux_tables(THD *thd, dict_table_t *table)
Lock all FTS AUX tables (for dropping table)
Definition: fts0fts.cc:1746
const char * FTS_PREFIX_5_7
FTS auxiliary table prefix that are common to all FT indexes.
Definition: fts0fts.cc:130
dberr_t fts_commit(trx_t *trx)
The given transaction is about to be committed; do whatever is necessary from the FTS system's POV.
Definition: fts0fts.cc:3252
void fts_cache_clear(fts_cache_t *cache)
Clear cache.
Definition: fts0fts.cc:917
void fts_freeze_aux_tables(const dict_table_t *table)
Freeze all auiliary tables to be not evictable if exist, with dict_mutex held.
Definition: fts0fts.cc:2057
dberr_t fts_empty_common_tables(trx_t *trx, dict_table_t *table)
Empty all common talbes.
Definition: fts0fts.cc:1583
char * fts_get_parent_table_name(const char *aux_table_name, ulint aux_table_len)
ulong fts_max_total_cache_size
Variable specifying the total memory allocated for FTS cache.
Definition: fts0fts.cc:81
void fts_savepoint_rollback_last_stmt(trx_t *trx)
Rollback to and including savepoint identified by name.
Definition: fts0fts.cc:5685
void fts_savepoint_laststmt_refresh(trx_t *trx)
Refresh last statement savepoint.
Definition: fts0fts.cc:5624
void fts_free(dict_table_t *table)
Free the FTS resources.
Definition: fts0fts.cc:5474
ulong fts_num_word_optimize
Variable specifying the number of word to optimize for each optimize table call.
Definition: fts0opt.cc:241
ulint innobase_mysql_fts_get_token(CHARSET_INFO *charset, const byte *start, const byte *end, fts_string_t *token)
Get the next token from the given string and store it in *token.
Definition: ha_innodb.cc:7828
float fts_rank_t
FTS rank type, which will be between 0 .
Definition: fts0fts.h:163
const char * FTS_SUFFIX_DELETED
Definition: fts0fts.cc:140
dberr_t fts_table_fetch_doc_ids(trx_t *trx, fts_table_t *fts_table, fts_doc_ids_t *doc_ids)
Read the rows from the FTS index.
Definition: fts0opt.cc:958
void fts_query_free_result(fts_result_t *result)
FTS Query free result, returned by fts_query().
Definition: fts0que.cc:3820
ulint fts_get_token_size(const CHARSET_INFO *cs, const char *token, ulint len)
Get token char size by charset.
Definition: fts0fts.cc:4688
constexpr size_t FTS_NUM_AUX_COMMON
The number of FTS AUX common table for a fulltext index.
Definition: fts0fts.h:109
fts_row_state
Type of a row during a transaction.
Definition: fts0fts.h:177
@ FTS_DELETE
Definition: fts0fts.h:180
@ FTS_INVALID
Definition: fts0fts.h:182
@ FTS_MODIFY
Definition: fts0fts.h:179
@ FTS_NOTHING
Definition: fts0fts.h:181
@ FTS_INSERT
Definition: fts0fts.h:178
unsigned short ib_uc_t
Since MySQL's character set support for Unicode is woefully inadequate (it supports basic operations ...
Definition: fts0fts.h:289
const char * FTS_SUFFIX_DELETED_CACHE
Definition: fts0fts.cc:141
void fts_trx_add_op(trx_t *trx, dict_table_t *table, doc_id_t doc_id, fts_row_state state, ib_vector_t *fts_indexes)
Notify the FTS system about an operation on an FTS-indexed table.
Definition: fts0fts.cc:2643
bool fts_is_aux_table_name(fts_aux_table_t *table, const char *name, ulint len)
Check if a table is an FTS auxiliary table name.
Definition: fts0fts.cc:5783
Prototypes for global functions in ha_innodb.cc that are called by InnoDB C code.
The simple hash table utility.
static int flags[50]
Definition: hp_test1.cc:40
static void start(mysql_harness::PluginFuncEnv *env)
Definition: http_auth_backend_plugin.cc:177
The memory management.
unsigned long long int ulonglong
Definition: my_inttypes.h:56
const std::string charset("charset")
Definition: commit_order_queue.h:34
static int wait(mysql_cond_t *that, mysql_mutex_t *mutex_arg, const char *, unsigned int)
Definition: mysql_cond_v1_native.cc:63
const char * table_name
Definition: rules_table_service.cc:56
Cursor end()
A past-the-end Cursor.
Definition: rules_table_service.cc:192
Query graph global types.
Record manager global types.
byte rec_t
Definition: rem0types.h:41
static bool reload(MYSQL_THD thd)
Reloads the rules into the in-memory table.
Definition: rewriter_plugin.cc:333
Row operation global types.
static bool rollback(THD *thd)
Abort the current statement and transaction.
Definition: sql_cmd_srs.cc:140
case opt name
Definition: sslopt-case.h:33
Definition: m_ctype.h:385
Definition: plugin_ftparser.h:191
Structure to manage FTS AUX table name and MDL during its drop.
Definition: fts0fts.h:166
std::vector< char * > aux_name
AUX table name.
Definition: fts0fts.h:168
Data structure for an index.
Definition: dict0mem.h:1046
Data structure for a database table.
Definition: dict0mem.h:1909
Structure for an SQL data tuple of fields (logical record)
Definition: data0data.h:694
For storing table info when checking for orphaned tables.
Definition: fts0fts.h:902
fts_table_type_t type
FTS table type.
Definition: fts0fts.h:916
table_id_t index_id
Table FT index id.
Definition: fts0fts.h:910
char * name
Name of the table.
Definition: fts0fts.h:913
table_id_t id
Table id.
Definition: fts0fts.h:904
table_id_t parent_id
Parent table id.
Definition: fts0fts.h:907
The cache for the FTS system.
Definition: fts0types.h:144
List of document ids that were added during a transaction.
Definition: fts0fts.h:275
ib_vector_t * doc_ids
document ids (each element is of type doc_id_t).
Definition: fts0fts.h:276
ib_alloc_t * self_heap
Allocator used to create an instance of this type and the doc_ids vector.
Definition: fts0fts.h:279
This type represents a single document field.
Definition: fts0types.h:272
Since we can have multiple FTS indexes on a table, we keep a per index cache of words etc.
Definition: fts0types.h:71
Query ranked doc ids.
Definition: fts0fts.h:300
ulint words_len
words len
Definition: fts0fts.h:308
fts_rank_t rank
Rank is between 0 .
Definition: fts0fts.h:303
byte * words
this contains the words that were queried and found in this document
Definition: fts0fts.h:305
doc_id_t doc_id
Document id.
Definition: fts0fts.h:301
Query result.
Definition: fts0fts.h:312
ib_rbt_t * rankings_by_id
RB tree of type fts_ranking_t indexed by doc id.
Definition: fts0fts.h:315
ib_rbt_t * rankings_by_rank
RB tree of type fts_ranking_t indexed by rank.
Definition: fts0fts.h:317
ib_rbt_node_t * current
Current element.
Definition: fts0fts.h:313
Information required for transaction savepoint handling.
Definition: fts0fts.h:239
ib_rbt_t * tables
Modified FTS tables.
Definition: fts0fts.h:244
char * name
First entry is always NULL, the default instance.
Definition: fts0fts.h:240
Stop word control infotmation.
Definition: fts0types.h:105
ib_alloc_t * heap
The memory allocator to use.
Definition: fts0types.h:107
An UTF-16 ro UTF-8 string.
Definition: fts0fts.h:292
ulint f_n_char
Number of characters.
Definition: fts0fts.h:296
ulint f_len
Length of the string in bytes.
Definition: fts0fts.h:295
byte * f_str
string, not necessary terminated in any way
Definition: fts0fts.h:293
This is used to generate the FTS auxiliary table name, we need the table id and the index id to gener...
Definition: fts0fts.h:324
space_index_t index_id
The index id.
Definition: fts0fts.h:333
CHARSET_INFO * charset
charset info if it is for FTS index auxiliary table
Definition: fts0fts.h:339
fts_table_type_t type
The auxiliary table type.
Definition: fts0fts.h:329
const dict_table_t * table
Parent table.
Definition: fts0fts.h:338
table_id_t table_id
The table id.
Definition: fts0fts.h:331
const char * suffix
The suffix of the fts auxiliary table name, can be NULL, not used everywhere (yet)
Definition: fts0fts.h:335
const char * parent
Parent table name, this is required only for the database name.
Definition: fts0fts.h:325
A token and its positions within a document.
Definition: fts0types.h:298
Information about one changed row in a transaction.
Definition: fts0fts.h:264
doc_id_t doc_id
Id of the ins/upd/del document.
Definition: fts0fts.h:265
fts_row_state state
state of the row
Definition: fts0fts.h:267
ib_vector_t * fts_indexes
The indexes that are affected.
Definition: fts0fts.h:269
Information about changes in a single transaction affecting the FTS system.
Definition: fts0fts.h:227
ib_vector_t * last_stmt
last_stmt
Definition: fts0fts.h:233
mem_heap_t * heap
heap
Definition: fts0fts.h:235
trx_t * trx
InnoDB transaction.
Definition: fts0fts.h:228
ib_vector_t * savepoints
Active savepoints, must have at least one element, the implied savepoint.
Definition: fts0fts.h:230
Information about changed rows in a transaction for a single table.
Definition: fts0fts.h:248
ib_rbt_t * rows
rows changed; indexed by doc-id, cells are fts_trx_row_t*
Definition: fts0fts.h:253
fts_trx_t * fts_trx
link to parent
Definition: fts0fts.h:251
dict_table_t * table
table
Definition: fts0fts.h:249
que_t * docs_added_graph
Definition: fts0fts.h:260
fts_doc_ids_t * added_doc_ids
list of added doc ids (NULL until the first addition)
Definition: fts0fts.h:256
Definition: ut0vec.h:204
Red black tree node.
Definition: ut0rbt.h:61
Red black tree instance.
Definition: ut0rbt.h:72
Definition: ut0vec.h:213
Definition: ut0wqueue.cc:43
The info structure stored at the beginning of a heap block.
Definition: mem0mem.h:302
Definition: que0que.h:301
Definition: result.h:30
Definition: trx0trx.h:675
Definition: row0upd.h:467
Transaction system global type definitions.
unsigned int uint
Definition: uca9-dump.cc:75
unsigned long int ulint
Definition: univ.i:406
Various utilities.
A vector of pointers to data items.
A work queue.