MySQL 8.4.3
Source Code Documentation
row0sel.h
Go to the documentation of this file.
1/*****************************************************************************
2
3Copyright (c) 1997, 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/row0sel.h
29 Select
30
31 Created 12/19/1997 Heikki Tuuri
32 *******************************************************/
33
34#ifndef row0sel_h
35#define row0sel_h
36
37#include "univ.i"
38
39#include "btr0pcur.h"
40#include "data0data.h"
41#include "dict0stats.h"
42#include "dict0types.h"
43#include "pars0sym.h"
44#include "que0types.h"
45#include "read0types.h"
46#include "row0mysql.h"
47#include "row0types.h"
48#include "trx0types.h"
49
50/** Creates a select node struct.
51 @return own: select node struct */
53 mem_heap_t *heap); /*!< in: memory heap where created */
54/** Frees the memory private to a select node when a query graph is freed,
55 does not free the heap where the node was originally created. */
56void sel_node_free_private(sel_node_t *node); /*!< in: select node struct */
57/** Frees a prefetch buffer for a column, including the dynamically allocated
58 memory for data stored there. */
60 sel_buf_t *prefetch_buf); /*!< in, own: prefetch buffer */
61
62/** Gets the plan node for the nth table in a join.
63@param[in] node select node
64@param[in] i get ith plan node
65@return plan node */
67
68/** Performs a select step. This is a high-level function used in SQL execution
69 graphs.
70 @return query thread to run next or NULL */
71que_thr_t *row_sel_step(que_thr_t *thr); /*!< in: query thread */
72/** Performs an execution step of an open or close cursor statement node.
73 @return query thread to run next or NULL */
74static inline que_thr_t *open_step(que_thr_t *thr); /*!< in: query thread */
75/** Performs a fetch for a cursor.
76 @return query thread to run next or NULL */
77que_thr_t *fetch_step(que_thr_t *thr); /*!< in: query thread */
78
79/** Copy used fields from cached row.
80Copy cache record field by field, don't touch fields that
81are not covered by current key.
82@param[out] buf Where to copy the MySQL row.
83@param[in] cached_rec What to copy (in MySQL row format).
84@param[in] prebuilt prebuilt struct. */
85void row_sel_copy_cached_fields_for_mysql(byte *buf, const byte *cached_rec,
86 row_prebuilt_t *prebuilt);
87
88// clang-format off
89/** Convert a row in the Innobase format to a row in the MySQL format.
90Note that the template in prebuilt may advise us to copy only a few
91columns to mysql_rec, other columns are left blank. All columns may not
92be needed in the query.
93@param[out] mysql_rec row in the MySQL format
94@param[in,out] prebuilt prebuilt structure
95@param[in] rec Innobase record in the index
96 which was described in prebuilt's
97 template, or in the clustered index;
98 must be protected by a page latch
99@param[in] vrow virtual columns
100@param[in] rec_clust true if rec is in the clustered index
101 instead of index which could belong to
102 prebuilt->index
103@param[in] rec_index index of rec
104@param[in] prebuilt_index prebuilt->index
105@param[in] offsets array returned by rec_get_offsets(rec)
106@param[in] clust_templ_for_sec true if rec belongs to secondary index
107 but the prebuilt->template is in
108 clustered index format and it
109 is used only for end range comparison
110@param[in] lob_undo the LOB undo information.
111@param[in,out] blob_heap If not null then use this heap for BLOBs
112@return true on success, false if not all columns could be retrieved */
113// clang-format on
114bool row_sel_store_mysql_rec(byte *mysql_rec, row_prebuilt_t *prebuilt,
115 const rec_t *rec, const dtuple_t *vrow,
116 bool rec_clust, const dict_index_t *rec_index,
117 const dict_index_t *prebuilt_index,
118 const ulint *offsets, bool clust_templ_for_sec,
119 lob::undo_vers_t *lob_undo,
120 mem_heap_t *&blob_heap);
121
122/** Converts a key value stored in MySQL format to an Innobase dtuple. The last
123field of the key value may be just a prefix of a fixed length field: hence
124the parameter key_len. But currently we do not allow search keys where the
125last field is only a prefix of the full key field len and print a warning if
126such appears.
127@param[in,out] tuple Tuple where to build; NOTE: we assume that the type info in
128the tuple is already according to index!
129@param[in] buf Buffer to use in field conversions; NOTE that dtuple->data may
130end up pointing inside buf so do not discard that buffer while the tuple is
131being used. See row_mysql_store_col_in_innobase_format() in the case of
132DATA_INT.
133@param[in] buf_len Buffer length.
134@param[in] index Index of the key value.
135@param[in] key_ptr MySQL key value
136@param[in] key_len MySQL key value length
137*/
139 ulint buf_len, dict_index_t *index,
140 const byte *key_ptr, ulint key_len);
141
142/** Searches for rows in the database. This is used in the interface to
143MySQL. This function opens a cursor, and also implements fetch next
144and fetch prev. NOTE that if we do a search with a full key value
145from a unique index (ROW_SEL_EXACT), then we will not store the cursor
146position and fetch next or fetch prev must not be tried to the cursor!
147
148@param[out] buf buffer for the fetched row in MySQL format
149@param[in] mode search mode PAGE_CUR_L
150@param[in,out] prebuilt prebuilt struct for the table handler;
151 this contains the info to search_tuple,
152 index; if search tuple contains 0 field then
153 we position the cursor at start or the end of
154 index, depending on 'mode'
155@param[in] match_mode 0 or ROW_SEL_EXACT or ROW_SEL_EXACT_PREFIX
156@param[in] direction 0 or ROW_SEL_NEXT or ROW_SEL_PREV;
157 Note: if this is != 0, then prebuilt must has a
158 pcur with stored position! In opening of a
159 cursor 'direction' should be 0.
160@return DB_SUCCESS, DB_RECORD_NOT_FOUND, DB_END_OF_INDEX, DB_DEADLOCK,
161DB_LOCK_TABLE_FULL, DB_CORRUPTION, or DB_TOO_BIG_RECORD */
162[[nodiscard]] static inline dberr_t row_search_for_mysql(
163 byte *buf, page_cur_mode_t mode, row_prebuilt_t *prebuilt, ulint match_mode,
164 ulint direction);
165
166/** Searches for rows in the database using cursor.
167Function is for temporary tables that are not shared across connections
168and so lot of complexity is reduced especially locking and transaction related.
169The cursor is an iterator over the table/index.
170
171@param[out] buf buffer for the fetched row in MySQL format
172@param[in] mode search mode PAGE_CUR_L
173@param[in,out] prebuilt prebuilt struct for the table handler;
174 this contains the info to search_tuple,
175 index; if search tuple contains 0 field then
176 we position the cursor at start or the end of
177 index, depending on 'mode'
178@param[in] match_mode 0 or ROW_SEL_EXACT or ROW_SEL_EXACT_PREFIX
179@param[in] direction 0 or ROW_SEL_NEXT or ROW_SEL_PREV;
180 Note: if this is != 0, then prebuilt must has a
181 pcur with stored position! In opening of a
182 cursor 'direction' should be 0.
183@return DB_SUCCESS or error code */
185 row_prebuilt_t *prebuilt,
186 ulint match_mode, ulint direction);
187
188/** Searches for rows in the database using cursor.
189Function is mainly used for tables that are shared accorss connection and
190so it employs technique that can help re-construct the rows that
191transaction is suppose to see.
192It also has optimization such as pre-caching the rows, using AHI, etc.
193
194@param[out] buf buffer for the fetched row in MySQL format
195@param[in] mode search mode PAGE_CUR_L
196@param[in,out] prebuilt prebuilt struct for the table handler;
197 this contains the info to search_tuple,
198 index; if search tuple contains 0 field then
199 we position the cursor at start or the end of
200 index, depending on 'mode'
201@param[in] match_mode 0 or ROW_SEL_EXACT or ROW_SEL_EXACT_PREFIX
202@param[in] direction 0 or ROW_SEL_NEXT or ROW_SEL_PREV;
203 Note: if this is != 0, then prebuilt must has a
204 pcur with stored position! In opening of a
205 cursor 'direction' should be 0.
206@return DB_SUCCESS or error code */
207[[nodiscard]] dberr_t row_search_mvcc(byte *buf, page_cur_mode_t mode,
208 row_prebuilt_t *prebuilt,
209 ulint match_mode, const ulint direction);
210
211/** Count rows in a R-Tree leaf level.
212 @return DB_SUCCESS if successful */
214 row_prebuilt_t *prebuilt, /*!< in: prebuilt struct for the
215 table handle; this contains the info
216 of search_tuple, index; if search
217 tuple contains 0 fields then we
218 position the cursor at the start or
219 the end of the index, depending on
220 'mode' */
221 ulint *n_rows, /*!< out: number of entries
222 seen in the consistent read */
223 ulint *n_dups); /*!< out: number of dup entries
224 seen in the consistent read */
225
226/** Read the max AUTOINC value from an index.
227 @return DB_SUCCESS if all OK else error code */
228[[nodiscard]] dberr_t row_search_max_autoinc(
229 dict_index_t *index, /*!< in: index to search */
230 const char *col_name, /*!< in: autoinc column name */
231 uint64_t *value); /*!< out: AUTOINC value read */
232
233/** A structure for caching column values for prefetched rows */
234struct sel_buf_t {
235 byte *data; /*!< data, or NULL; if not NULL, this field
236 has allocated memory which must be explicitly
237 freed; can be != NULL even when len is
238 UNIV_SQL_NULL */
239 ulint len; /*!< data length or UNIV_SQL_NULL */
241 /*!< size of memory buffer allocated for data:
242 this can be more than len; this is defined
243 when data != NULL */
244};
245
246/** Query plan */
247struct plan_t {
248 dict_table_t *table; /*!< table struct in the dictionary
249 cache */
250 dict_index_t *index; /*!< table index used in the search */
251 btr_pcur_t pcur; /*!< persistent cursor used to search
252 the index */
253 bool asc; /*!< true if cursor traveling upwards */
254 bool pcur_is_open; /*!< true if pcur has been positioned
255 and we can try to fetch new rows */
256 bool cursor_at_end; /*!< true if the cursor is open but
257 we know that there are no more
258 qualifying rows left to retrieve from
259 the index tree; NOTE though, that
260 there may still be unprocessed rows in
261 the prefetch stack; always false when
262 pcur_is_open is false */
264 /*!< true if the pcur position has been
265 stored and the record it is positioned
266 on has already been processed */
267 que_node_t **tuple_exps; /*!< array of expressions
268 which are used to calculate
269 the field values in the search
270 tuple: there is one expression
271 for each field in the search
272 tuple */
273 dtuple_t *tuple; /*!< search tuple */
274 page_cur_mode_t mode; /*!< search mode: PAGE_CUR_G, ... */
275 ulint n_exact_match; /*!< number of first fields in
276 the search tuple which must be
277 exactly matched */
278 bool unique_search; /*!< true if we are searching an
279 index record with a unique key */
280 ulint n_rows_fetched; /*!< number of rows fetched using pcur
281 after it was opened */
282 ulint n_rows_prefetched; /*!< number of prefetched rows cached
283 for fetch: fetching several rows in
284 the same mtr saves CPU time */
285 ulint first_prefetched; /*!< index of the first cached row in
286 select buffer arrays for each column */
287 bool no_prefetch; /*!< no prefetch for this table */
288 sym_node_list_t columns; /*!< symbol table nodes for the columns
289 to retrieve from the table */
291 /** conditions which determine the fetch limit of the index segment we have to
292 look at: when one of these fails, the result set has been exhausted for the
293 cursor in this index; these conditions are normalized so that in a comparison
294 the column for this table is the first argument */
296 /** the rest of search conditions we can test at this table in a join */
298 bool must_get_clust; /*!< true if index is a non-clustered
299 index and we must also fetch the
300 clustered index record; this is the
301 case if the non-clustered record does
302 not contain all the needed columns, or
303 if this is a single-table explicit
304 cursor, or a searched update or
305 delete */
306 ulint *clust_map; /*!< map telling how clust_ref is built
307 from the fields of a non-clustered
308 record */
309 dtuple_t *clust_ref; /*!< the reference to the clustered
310 index entry is built here if index is
311 a non-clustered index */
312 btr_pcur_t clust_pcur; /*!< if index is non-clustered, we use
313 this pcur to search the clustered
314 index */
315 mem_heap_t *old_vers_heap; /*!< memory heap used in building an old
316 version of a row, or NULL */
317};
318
319/** Select node states */
321 SEL_NODE_CLOSED, /*!< it is a declared cursor which is not
322 currently open */
323 SEL_NODE_OPEN, /*!< intention locks not yet set on tables */
324 SEL_NODE_FETCH, /*!< intention locks have been set */
325 SEL_NODE_NO_MORE_ROWS /*!< cursor has reached the result set end */
327
328/** Select statement node */
330 que_common_t common; /*!< node type: QUE_NODE_SELECT */
331 enum sel_node_state state; /*!< node state */
332 que_node_t *select_list; /*!< select list */
333 sym_node_t *into_list; /*!< variables list or NULL */
334 sym_node_t *table_list; /*!< table list */
335 bool asc; /*!< true if the rows should be fetched
336 in an ascending order */
337 bool set_x_locks; /*!< true if the cursor is for update or
338 delete, which means that a row x-lock
339 should be placed on the cursor row */
340 ulint row_lock_mode; /*!< LOCK_X or LOCK_S */
341 ulint n_tables; /*!< number of tables */
342 ulint fetch_table; /*!< number of the next table to access
343 in the join */
344 plan_t *plans; /*!< array of n_tables many plan nodes
345 containing the search plan and the
346 search data structures */
347 que_node_t *search_cond; /*!< search condition */
348 ReadView *read_view; /*!< if the query is a non-locking
349 consistent read, its read view is
350 placed here, otherwise NULL */
351 bool consistent_read; /*!< true if the select is a consistent,
352 non-locking read */
353 order_node_t *order_by; /*!< order by column definition, or
354 NULL */
355 bool is_aggregate; /*!< true if the select list consists of
356 aggregate functions */
358 /*!< true if the aggregate row has
359 already been fetched for the current
360 cursor */
361
362 /** this is true if the select is in a single-table explicit cursor which can
363 get updated within the stored procedure, or in a searched update or delete;
364 NOTE that to determine of an explicit cursor if it can get updated, the
365 parser checks from a stored procedure if it contains positioned update or
366 delete statements */
368 /** not NULL if an explicit cursor */
370 /** variables whose values we have to copy when an explicit cursor is opened,
371 so that they do not change between fetches */
372 sym_node_list_t copy_variables;
373};
374
375/** Fetch statement node */
377 que_common_t common; /*!< type: QUE_NODE_FETCH */
378 sel_node_t *cursor_def; /*!< cursor definition */
379 sym_node_t *into_list; /*!< variables to set */
380
381 pars_user_func_t *func; /*!< User callback function or NULL.
382 The first argument to the function
383 is a sel_node_t*, containing the
384 results of the SELECT operation for
385 one row. If the function returns
386 NULL, it is not interested in
387 further rows and the cursor is
388 modified so (cursor % NOTFOUND) is
389 true. If it returns not-NULL,
390 continue normally. */
391};
392
393/** Open or close cursor operation type */
395 ROW_SEL_OPEN_CURSOR, /*!< open cursor */
396 ROW_SEL_CLOSE_CURSOR /*!< close cursor */
398
399/** Open or close cursor statement node */
401 que_common_t common; /*!< type: QUE_NODE_OPEN */
402 enum open_node_op op_type; /*!< operation type: open or
403 close cursor */
404 sel_node_t *cursor_def; /*!< cursor definition */
405};
406
407/** Search direction for the MySQL interface */
409 ROW_SEL_NEXT = 1, /*!< ascending direction */
410 ROW_SEL_PREV = 2 /*!< descending direction */
412
413/** Match mode for the MySQL interface */
415 ROW_SEL_EXACT = 1, /*!< search using a complete key value */
416 ROW_SEL_EXACT_PREFIX /*!< search using a key prefix which
417 must match rows: the prefix may
418 contain an incomplete field (the last
419 field in prefix may be just a prefix
420 of a fixed length column) */
422
423/** Stores a non-SQL-NULL field in the MySQL format. The counterpart of this
424function is row_mysql_store_col_in_innobase_format() in row0mysql.cc.
425@param[in,out] dest buffer where to store; NOTE
426 that BLOBs are not in themselves stored
427 here: the caller must allocate and copy
428 the BLOB into buffer before, and pass
429 the pointer to the BLOB in 'data'
430@param[in] templ MySQL column template. Its following fields
431 are referenced: type, is_unsigned,
432mysql_col_len, mbminlen, mbmaxlen
433@param[in] index InnoDB index
434@param[in] field_no templ->rec_field_no or templ->clust_rec_field_no
435 or templ->icp_rec_field_no
436@param[in] data data to store
437@param[in] len length of the data
438@param[in] sec_field secondary index field no if the secondary index
439 record but the prebuilt template is in
440 clustered index format and used only for end
441 range comparison. */
443 byte *dest, const mysql_row_templ_t *templ, const dict_index_t *index,
444 IF_DEBUG(ulint field_no, ) const byte *data,
445 ulint len IF_DEBUG(, ulint sec_field));
446
447/** Convert a non-SQL-NULL field from Innobase format to MySQL format. */
449 byte *dest, const mysql_row_templ_t *templ, const dict_index_t *idx,
450 ulint field, const byte *src, ulint len, ulint sec) {
452 dest, templ, idx, IF_DEBUG(field, ) src, len IF_DEBUG(, sec));
453}
454
455/** Search the record present in innodb_table_stats table using
456db_name, table_name and fill it in table stats structure.
457@param[in] db_name database name
458@param[in] tbl_name table name
459@param[out] table_stats stats table structure.
460@return true if successful else false. */
461bool row_search_table_stats(const char *db_name, const char *tbl_name,
462 TableStatsRecord &table_stats);
463
464/** Search the record present in innodb_index_stats using
465db_name, table name and index_name and fill the
466cardinality for the each column.
467@param[in] db_name database name
468@param[in] tbl_name table name
469@param[in] index_name index name
470@param[in] col_offset offset of the column in the index
471@param[out] cardinality cardinality of the column.
472@return true if successful else false. */
473bool row_search_index_stats(const char *db_name, const char *tbl_name,
474 const char *index_name, ulint col_offset,
475 ulonglong *cardinality);
476
477#include "row0sel.ic"
478
479#endif
The index tree persistent cursor.
Read view lists the trx ids of those transactions for which a consistent read should not see the modi...
Definition: read0types.h:48
Represent the record of innodb_table_stats table.
Definition: dict0stats.h:157
static struct my_cs_file_section_st sec[]
Definition: ctype.cc:166
SQL data field and tuple.
dberr_t
Definition: db0err.h:39
Code used for calculating and manipulating table statistics.
Data dictionary global types.
unsigned long long int ulonglong
Definition: my_inttypes.h:56
Definition: buf0block_hint.cc:30
const char * db_name
Definition: rules_table_service.cc:55
mode
Definition: file_handle.h:61
page_cur_mode_t
Definition: page0types.h:176
SQL parser symbol table.
Query graph global types.
void que_node_t
Definition: que0types.h:41
Cursor read.
byte rec_t
Definition: rem0types.h:41
Interface between Innobase row operations and MySQL.
void sel_node_free_private(sel_node_t *node)
Frees the memory private to a select node when a query graph is freed, does not free the heap where t...
Definition: row0sel.cc:367
bool row_search_index_stats(const char *db_name, const char *tbl_name, const char *index_name, ulint col_offset, ulonglong *cardinality)
Search the record present in innodb_index_stats using db_name, table name and index_name and fill the...
Definition: row0sel.cc:6397
void row_sel_copy_cached_fields_for_mysql(byte *buf, const byte *cached_rec, row_prebuilt_t *prebuilt)
Copy used fields from cached row.
Definition: row0sel.cc:3521
static que_thr_t * open_step(que_thr_t *thr)
Performs an execution step of an open or close cursor statement node.
static plan_t * sel_node_get_nth_plan(sel_node_t *node, ulint i)
Gets the plan node for the nth table in a join.
row_sel_direction
Search direction for the MySQL interface.
Definition: row0sel.h:408
@ ROW_SEL_PREV
descending direction
Definition: row0sel.h:410
@ ROW_SEL_NEXT
ascending direction
Definition: row0sel.h:409
void sel_col_prefetch_buf_free(sel_buf_t *prefetch_buf)
Frees a prefetch buffer for a column, including the dynamically allocated memory for data stored ther...
Definition: row0sel.cc:556
static void row_sel_field_store_in_mysql_format(byte *dest, const mysql_row_templ_t *templ, const dict_index_t *idx, ulint field, const byte *src, ulint len, ulint sec)
Convert a non-SQL-NULL field from Innobase format to MySQL format.
Definition: row0sel.h:448
sel_node_t * sel_node_create(mem_heap_t *heap)
Creates a select node struct.
Definition: row0sel.cc:350
que_thr_t * row_sel_step(que_thr_t *thr)
Performs a select step.
Definition: row0sel.cc:2110
dberr_t row_search_mvcc(byte *buf, page_cur_mode_t mode, row_prebuilt_t *prebuilt, ulint match_mode, const ulint direction)
Searches for rows in the database using cursor.
Definition: row0sel.cc:4420
void row_sel_field_store_in_mysql_format_func(byte *dest, const mysql_row_templ_t *templ, const dict_index_t *index, ulint field_no, const byte *data, ulint len, ulint sec_field)
Stores a non-SQL-NULL field in the MySQL format.
Definition: row0sel.cc:2501
dberr_t row_search_no_mvcc(byte *buf, page_cur_mode_t mode, row_prebuilt_t *prebuilt, ulint match_mode, ulint direction)
Searches for rows in the database using cursor.
Definition: row0sel.cc:3955
sel_node_state
Select node states.
Definition: row0sel.h:320
@ SEL_NODE_NO_MORE_ROWS
cursor has reached the result set end
Definition: row0sel.h:325
@ SEL_NODE_FETCH
intention locks have been set
Definition: row0sel.h:324
@ SEL_NODE_OPEN
intention locks not yet set on tables
Definition: row0sel.h:323
@ SEL_NODE_CLOSED
it is a declared cursor which is not currently open
Definition: row0sel.h:321
que_thr_t * fetch_step(que_thr_t *thr)
Performs a fetch for a cursor.
Definition: row0sel.cc:2209
void row_sel_convert_mysql_key_to_innobase(dtuple_t *tuple, byte *buf, ulint buf_len, dict_index_t *index, const byte *key_ptr, ulint key_len)
Converts a key value stored in MySQL format to an Innobase dtuple.
Definition: row0sel.cc:2259
static dberr_t row_search_for_mysql(byte *buf, page_cur_mode_t mode, row_prebuilt_t *prebuilt, ulint match_mode, ulint direction)
Searches for rows in the database.
row_sel_match_mode
Match mode for the MySQL interface.
Definition: row0sel.h:414
@ ROW_SEL_EXACT_PREFIX
search using a key prefix which must match rows: the prefix may contain an incomplete field (the last...
Definition: row0sel.h:416
@ ROW_SEL_EXACT
search using a complete key value
Definition: row0sel.h:415
dberr_t row_search_max_autoinc(dict_index_t *index, const char *col_name, uint64_t *value)
Read the max AUTOINC value from an index.
Definition: row0sel.cc:6272
dberr_t row_count_rtree_recs(row_prebuilt_t *prebuilt, ulint *n_rows, ulint *n_dups)
Count rows in a R-Tree leaf level.
Definition: row0sel.cc:6076
open_node_op
Open or close cursor operation type.
Definition: row0sel.h:394
@ ROW_SEL_CLOSE_CURSOR
close cursor
Definition: row0sel.h:396
@ ROW_SEL_OPEN_CURSOR
open cursor
Definition: row0sel.h:395
bool row_search_table_stats(const char *db_name, const char *tbl_name, TableStatsRecord &table_stats)
Search the record present in innodb_table_stats table using db_name, table_name and fill it in table ...
Definition: row0sel.cc:6335
bool row_sel_store_mysql_rec(byte *mysql_rec, row_prebuilt_t *prebuilt, const rec_t *rec, const dtuple_t *vrow, bool rec_clust, const dict_index_t *rec_index, const dict_index_t *prebuilt_index, const ulint *offsets, bool clust_templ_for_sec, lob::undo_vers_t *lob_undo, mem_heap_t *&blob_heap)
Convert a row in the Innobase format to a row in the MySQL format.
Definition: row0sel.cc:2891
Select.
Row operation global types.
Definition: btr0pcur.h:99
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
Fetch statement node.
Definition: row0sel.h:376
sel_node_t * cursor_def
cursor definition
Definition: row0sel.h:378
pars_user_func_t * func
User callback function or NULL.
Definition: row0sel.h:381
sym_node_t * into_list
variables to set
Definition: row0sel.h:379
que_common_t common
type: QUE_NODE_FETCH
Definition: row0sel.h:377
A predefined function or operator node in a parsing tree; this construct is also used for some non-fu...
Definition: pars0pars.h:497
The list of modifications to be applied on LOBs to get older versions.
Definition: lob0undo.h:146
The info structure stored at the beginning of a heap block.
Definition: mem0mem.h:302
Definition: row0mysql.h:455
Open or close cursor statement node.
Definition: row0sel.h:400
enum open_node_op op_type
operation type: open or close cursor
Definition: row0sel.h:402
sel_node_t * cursor_def
cursor definition
Definition: row0sel.h:404
que_common_t common
type: QUE_NODE_OPEN
Definition: row0sel.h:401
An order-by node in a select.
Definition: pars0pars.h:516
User-supplied function and argument.
Definition: pars0pars.h:467
Query plan.
Definition: row0sel.h:247
ulint first_prefetched
index of the first cached row in select buffer arrays for each column
Definition: row0sel.h:285
page_cur_mode_t mode
search mode: PAGE_CUR_G, ...
Definition: row0sel.h:274
Cond_list other_conds
the rest of search conditions we can test at this table in a join
Definition: row0sel.h:297
ulint n_rows_prefetched
number of prefetched rows cached for fetch: fetching several rows in the same mtr saves CPU time
Definition: row0sel.h:282
dtuple_t * clust_ref
the reference to the clustered index entry is built here if index is a non-clustered index
Definition: row0sel.h:309
sym_node_list_t columns
symbol table nodes for the columns to retrieve from the table
Definition: row0sel.h:288
bool no_prefetch
no prefetch for this table
Definition: row0sel.h:287
bool unique_search
true if we are searching an index record with a unique key
Definition: row0sel.h:278
dict_table_t * table
table struct in the dictionary cache
Definition: row0sel.h:248
mem_heap_t * old_vers_heap
memory heap used in building an old version of a row, or NULL
Definition: row0sel.h:315
bool must_get_clust
true if index is a non-clustered index and we must also fetch the clustered index record; this is the...
Definition: row0sel.h:298
bool asc
true if cursor traveling upwards
Definition: row0sel.h:253
dtuple_t * tuple
search tuple
Definition: row0sel.h:273
bool pcur_is_open
true if pcur has been positioned and we can try to fetch new rows
Definition: row0sel.h:254
que_node_t ** tuple_exps
array of expressions which are used to calculate the field values in the search tuple: there is one e...
Definition: row0sel.h:267
bool cursor_at_end
true if the cursor is open but we know that there are no more qualifying rows left to retrieve from t...
Definition: row0sel.h:256
btr_pcur_t clust_pcur
if index is non-clustered, we use this pcur to search the clustered index
Definition: row0sel.h:312
dict_index_t * index
table index used in the search
Definition: row0sel.h:250
UT_LIST_BASE_NODE_T_EXTERN(func_node_t, cond_list) Cond_list
Definition: row0sel.h:290
bool stored_cursor_rec_processed
true if the pcur position has been stored and the record it is positioned on has already been process...
Definition: row0sel.h:263
ulint n_exact_match
number of first fields in the search tuple which must be exactly matched
Definition: row0sel.h:275
Cond_list end_conds
conditions which determine the fetch limit of the index segment we have to look at: when one of these...
Definition: row0sel.h:295
ulint n_rows_fetched
number of rows fetched using pcur after it was opened
Definition: row0sel.h:280
btr_pcur_t pcur
persistent cursor used to search the index
Definition: row0sel.h:251
ulint * clust_map
map telling how clust_ref is built from the fields of a non-clustered record
Definition: row0sel.h:306
Definition: que0types.h:51
Definition: que0que.h:242
A struct for (sometimes lazily) prebuilt structures in an Innobase table handle used within MySQL; th...
Definition: row0mysql.h:515
A structure for caching column values for prefetched rows.
Definition: row0sel.h:234
byte * data
data, or NULL; if not NULL, this field has allocated memory which must be explicitly freed; can be !...
Definition: row0sel.h:235
ulint len
data length or UNIV_SQL_NULL
Definition: row0sel.h:239
ulint val_buf_size
size of memory buffer allocated for data: this can be more than len; this is defined when data !...
Definition: row0sel.h:240
Select statement node.
Definition: row0sel.h:329
plan_t * plans
array of n_tables many plan nodes containing the search plan and the search data structures
Definition: row0sel.h:344
sym_node_list_t copy_variables
variables whose values we have to copy when an explicit cursor is opened, so that they do not change ...
Definition: row0sel.h:372
sym_node_t * into_list
variables list or NULL
Definition: row0sel.h:333
ulint row_lock_mode
LOCK_X or LOCK_S.
Definition: row0sel.h:340
que_common_t common
node type: QUE_NODE_SELECT
Definition: row0sel.h:330
bool consistent_read
true if the select is a consistent, non-locking read
Definition: row0sel.h:351
bool asc
true if the rows should be fetched in an ascending order
Definition: row0sel.h:335
sym_node_t * explicit_cursor
not NULL if an explicit cursor
Definition: row0sel.h:369
order_node_t * order_by
order by column definition, or NULL
Definition: row0sel.h:353
que_node_t * select_list
select list
Definition: row0sel.h:332
bool can_get_updated
this is true if the select is in a single-table explicit cursor which can get updated within the stor...
Definition: row0sel.h:367
que_node_t * search_cond
search condition
Definition: row0sel.h:347
ReadView * read_view
if the query is a non-locking consistent read, its read view is placed here, otherwise NULL
Definition: row0sel.h:348
ulint n_tables
number of tables
Definition: row0sel.h:341
bool aggregate_already_fetched
true if the aggregate row has already been fetched for the current cursor
Definition: row0sel.h:357
bool set_x_locks
true if the cursor is for update or delete, which means that a row x-lock should be placed on the cur...
Definition: row0sel.h:337
ulint fetch_table
number of the next table to access in the join
Definition: row0sel.h:342
sym_node_t * table_list
table list
Definition: row0sel.h:334
bool is_aggregate
true if the select list consists of aggregate functions
Definition: row0sel.h:355
enum sel_node_state state
node state
Definition: row0sel.h:331
Symbol table node.
Definition: pars0sym.h:113
Transaction system global type definitions.
Version control for database, common definitions, and include files.
#define IF_DEBUG(...)
Definition: univ.i:674
unsigned long int ulint
Definition: univ.i:406
#define UT_LIST_BASE_NODE_T_EXTERN(t, m)
A variant of UT_LIST_BASE_NODE_T to be used in rare cases where the full definition of t is not yet i...
Definition: ut0lst.h:279