MySQL 9.1.0
Source Code Documentation
item_subselect.h
Go to the documentation of this file.
1#ifndef ITEM_SUBSELECT_INCLUDED
2#define ITEM_SUBSELECT_INCLUDED
3
4/* Copyright (c) 2002, 2024, Oracle and/or its affiliates.
5
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License, version 2.0,
8 as published by the Free Software Foundation.
9
10 This program is designed to work with certain software (including
11 but not limited to OpenSSL) that is licensed under separate terms,
12 as designated in a particular file or component or in included license
13 documentation. The authors of MySQL hereby grant you an additional
14 permission to link the program and your derivative works with the
15 separately licensed software that they have either included with
16 the program or referenced in the documentation.
17
18 This program is distributed in the hope that it will be useful,
19 but WITHOUT ANY WARRANTY; without even the implied warranty of
20 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 GNU General Public License, version 2.0, for more details.
22
23 You should have received a copy of the GNU General Public License
24 along with this program; if not, write to the Free Software
25 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
26
27/// Implements classes that represent subqueries and predicates containing
28/// table subqueries.
29
30#include <assert.h>
31#include <sys/types.h>
32
33#include <cstddef>
34#include <memory> // unique_ptr
35#include <vector>
36
37#include "field_types.h" // enum_field_types
38#include "my_alloc.h" // Destroy_only
39
40#include "my_inttypes.h"
41#include "my_table_map.h"
42#include "my_time.h"
44#include "mysql_time.h"
45#include "sql/comp_creator.h"
46#include "sql/enum_query_type.h"
47#include "sql/item.h" // Item_result_field
48#include "sql/iterators/row_iterator.h" // IWYU pragma: keep
49#include "sql/parse_location.h" // POS
51#include "sql/sql_const.h"
53#include "template_utils.h"
54
55class Comp_creator;
56class Field;
59class JOIN;
60class Json_wrapper;
61class PT_subquery;
65class Query_block;
67class String;
68class THD;
70class my_decimal;
72struct AccessPath;
73class Table_ref;
74
75template <class T>
76class List;
77
78/// Base class that is common to all subqueries and subquery predicates
79
82
83 public:
85
86 /**
87 If !=NO_PLAN_IDX: this Item is in the condition attached to the JOIN_TAB
88 having this index in the parent JOIN.
89 */
91
92 // For EXPLAIN.
95
96 // For EXPLAIN. Only valid if engine_type() == HASH_SJ_ENGINE.
97 const TABLE *get_table() const;
98 const Index_lookup &index_lookup() const;
100
101 void create_iterators(THD *thd);
102 virtual AccessPath *root_access_path() const { return nullptr; }
103
105 SCALAR_SUBQUERY, ///< Scalar or row subquery
106 EXISTS_SUBQUERY, ///< [NOT] EXISTS subquery predicate
107 IN_SUBQUERY, ///< [NOT] IN subquery predicate
108 ALL_SUBQUERY, ///< comp-op ALL quantified comparison predicate
109 ANY_SUBQUERY ///< comp-op ANY quantified comparison predicate
110 };
111
112 /// Accumulate used tables
116 }
117
118 /// Return whether this subquery references any tables in the directly
119 /// containing query block, i.e. whether there are outer references to the
120 /// containing block inside the subquery.
122 return (subquery_used_tables() & ~PSEUDO_TABLE_BITS) != 0;
123 }
124
125 virtual Subquery_type subquery_type() const = 0;
126
127 /**
128 @returns whether this subquery is a single column scalar subquery.
129 (Note that scalar and row subqueries are both represented as
130 scalar subqueries, this function can be used to distinguish them)
131 */
132 virtual bool is_single_column_scalar_subquery() const { return false; }
133
134 void cleanup() override;
135 /**
136 Reset state after a single execution of a subquery, useful when a
137 dependent subquery must be evaluated multiple times for varying values
138 of the outer references.
139 This is a lighter cleanup procedure than the one provided by cleanup().
140 */
141 virtual void reset() {
142 m_value_assigned = false;
143 null_value = true;
144 }
145 bool is_value_assigned() const { return m_value_assigned; }
148 enum Type type() const override;
149 bool is_null() override { return update_null_value() || null_value; }
150 bool fix_fields(THD *thd, Item **ref) override;
151 void fix_after_pullout(Query_block *parent_query_block,
152 Query_block *removed_query_block) override;
153 virtual bool exec(THD *thd);
154 table_map used_tables() const override { return m_used_tables_cache; }
155 table_map not_null_tables() const override { return 0; }
156 /// @returns used tables for subquery (excluding any left-hand expression)
158 Item *get_tmp_table_item(THD *thd) override;
159 void update_used_tables() override;
160 void print(const THD *thd, String *str,
161 enum_query_type query_type) const override;
162
165 }
166
167 /*
168 True if this subquery has been already evaluated. Implemented only for
169 single select and union subqueries only.
170 */
171 bool is_evaluated() const;
172 bool is_uncacheable() const;
173
174 /**
175 Used by max/min subquery to initialize value presence registration
176 mechanism. Engine calls this function before re-execution of subquery.
177 */
178 virtual void reset_has_values() {}
179 /**
180 @returns the "place" where this subquery is located in the simply
181 containing query block.
182 */
184
185 bool walk(Item_processor processor, enum_walk walk, uchar *arg) override;
186 bool explain_subquery_checker(uchar **arg) override;
187 bool inform_item_in_cond_of_tab(uchar *arg) override;
188 bool clean_up_after_removal(uchar *arg) override;
189
192 pointer_cast<Check_function_as_value_generator_parameters *>(args);
193 func_arg->err_code = func_arg->get_unnamed_function_error_code();
194 return true;
195 }
196
197 /// argument used by walk method collect_scalar_subqueries ("css")
199 ///< accumulated all subq (or aggregates) found
200 std::vector<Item_subselect *> list;
203 bool contains(Query_expression *candidate) {
204 for (auto sq : list) {
205 if (sq->m_query_expr == candidate) return true;
206 }
207 return false;
208 }
209 };
210
211 bool collect_subqueries(uchar *) override;
212 Item *replace_item_field(uchar *arg) override;
213 Item *replace_item_view_ref(uchar *arg) override;
214
215 protected:
217 explicit Item_subselect(const POS &pos) : super(pos) { set_subquery(); }
218 /**
219 Bind this subquery object with the supplied query expression.
220 As part of transformations, this function may re-bind the subquery to
221 a different query expression.
222
223 @param qe supplied query expression
224 */
225 void bind(Query_expression *qe);
226
227 /// The query expression of the subquery
228 Query_expression *m_query_expr{nullptr}; // Actual value set in construction
229
230 /// The query result object associated with the query expression
232
233 /// Only relevant for Item_in_subselect; optimized structure used for
234 /// execution in place of running the entire subquery.
236
237 /// cache of used tables
239 /// cache of used tables from subquery only (not including LHS of IN subquery)
241
242 /// allowed number of columns (1 for scalar subqueries)
243 uint m_max_columns{0}; // Irrelevant value, actually set during construction
244 /// where subquery is placed
246
247 private:
248 bool subq_opt_away_processor(uchar *arg) override;
249
250 /// Accumulate properties from underlying query expression
252 /// Accumulate properties from underlying query block
254 /// Accumulate properties from a selected expression within a query block.
255 void accumulate_expression(Item *item);
256 /// Accumulate properties from a condition or GROUP/ORDER within a query
257 /// block.
258 void accumulate_condition(Item *item);
259
260 /// True if value has been assigned to subquery
261 bool m_value_assigned{false};
262 /**
263 Whether or not execution of this subquery has been traced by
264 optimizer tracing already. If optimizer trace option
265 REPEATED_SUBSELECT is disabled, this is used to disable tracing
266 after the first one.
267 */
268 bool m_traced_before{false};
269};
270
271/// Class that represents scalar subquery and row subquery
272
274 public:
277
278 bool fix_fields(THD *thd, Item **ref) override;
279 void cleanup() override;
280 Subquery_type subquery_type() const override { return SCALAR_SUBQUERY; }
281 bool create_row(const mem_root_deque<Item *> &item_list, Item_cache **row,
282 bool possibly_empty);
283
284 bool is_single_column_scalar_subquery() const override;
285
286 void reset() override;
287 void store(uint i, Item *item);
288 double val_real() override;
289 longlong val_int() override;
290 String *val_str(String *) override;
291 my_decimal *val_decimal(my_decimal *) override;
292 bool val_json(Json_wrapper *result) override;
293 bool get_date(MYSQL_TIME *ltime, my_time_flags_t fuzzydate) override;
294 bool get_time(MYSQL_TIME *ltime) override;
295 bool val_bool() override;
296 enum Item_result result_type() const override;
297 bool resolve_type(THD *) override;
298
299 /*
300 Mark the subquery as having no rows.
301 If there are aggregate functions (in the outer query),
302 we need to generate a NULL row. @c return_zero_rows().
303 */
304 void no_rows_in_result() override;
305
306 uint cols() const override;
307
308 /**
309 @note that this returns the i-th element of the SELECT list.
310 To check for nullability, look at this->is_nullable() and not
311 element_index[i]->is_nullable(), since the selected expressions are
312 always NULL if the subquery is empty.
313 */
314 Item *element_index(uint i) override { return m_row[i]; }
315 Item **addr(uint i) override { return pointer_cast<Item **>(m_row) + i; }
316 bool check_cols(uint c) override;
317 bool null_inside() override;
318 void bring_value() override;
319
320 bool collect_scalar_subqueries(uchar *) override;
321 virtual bool is_maxmin() const { return false; }
322
323 /**
324 Argument for walk method replace_scalar_subquery
325 */
327 ///< subquery to be replaced with ␓field from derived table
329 ///< The derived table of the transform
331 ///< the replacement field
333 ///< The transformed query block.
335 ///< The immediately surrounding query block. This will be the transformed
336 ///< block or a subquery of it
338 ///< True if subquery's selected item contains a COUNT aggregate
339 bool m_add_coalesce{false};
340 ///< Presence of HAVING clause in subquery: Only relevant if
341 ///< \c m_add_coalesce is true
343 ///< Index of field holding value of having clause in derived table's list
344 ///< of fields. Only relevant if \c m_add_coalesce is true
346
348 TABLE *derived, Field *field,
349 Query_block *select, bool add_coalesce,
350 bool add_having_compensation, uint having_idx)
351 : m_target(target),
352 m_derived(derived),
353 m_field(field),
354 m_outer_query_block(select),
355 m_inner_query_block(select),
356 m_add_coalesce(add_coalesce),
357 m_add_having_compensation(add_having_compensation),
358 m_having_idx(having_idx) {}
359 };
360
361 Item *replace_scalar_subquery(uchar *arge) override;
362 /**
363 This method is used to implement a special case of semantic tree
364 rewriting, mandated by a SQL:2003 exception in the specification.
365 The only caller of this method is handle_sql2003_note184_exception(),
366 see the code there for more details.
367 Note that this method breaks the object internal integrity, by
368 removing it's association with the corresponding Query_block,
369 making this object orphan from the parse tree.
370 No other method, beside the destructor, should be called on this
371 object, as it is now invalid.
372 @return the Query_block structure that was given in the constructor.
373 */
375 std::optional<ContainedSubquery> get_contained_subquery(
376 const Query_block *outer_query_block) override;
378
379 private:
380 /// Value cache of a scalar subquery
382 /**
383 Value cache for a row or scalar subquery. In case of a scalar subquery,
384 m_row points directly at m_value. In case of a row subquery, m_row
385 is an array of pointers to individual Item_cache objects.
386 */
387 Item_cache **m_row{nullptr};
388 bool m_no_rows{false}; ///< @c no_rows_in_result
389};
390
391/* used in static ALL/ANY optimization */
393 public:
394 /**
395 Create an Item for use in transformation of quantified comparison
396 predicates that can be evaluated using MAX or MIN aggregation.
397
398 @param parent The quantified comparison predicate that is transformed.
399 @param query_block The query block representing the inner part of the subq.
400 @param max_arg Whether the aggregation is for MAX or MIN.
401 */
403 bool max_arg);
404 void print(const THD *thd, String *str,
405 enum_query_type query_type) const override;
406 void cleanup() override;
407 bool has_values() const { return m_has_values; }
408 void register_value() { m_has_values = true; }
409 void reset_has_values() override { m_has_values = false; }
410 bool is_maxmin() const override { return true; }
411
412 private:
413 bool m_max; ///< True if performing MAX, false if MIN
414 bool m_has_values{false}; ///< Set if we have found at least one row
415};
416
417/// Classes that represent predicates over table subqueries:
418/// [NOT] EXISTS, [NOT] IN, ANY/SOME and ALL
419
420/**
421 Strategy which will be used to handle this subquery: flattening to a
422 semi-join, conversion to a derived table, rewrite of IN to EXISTS...
423 Sometimes the strategy is first only a candidate, then the real decision
424 happens in a second phase. Other times the first decision is final.
425 */
426enum class Subquery_strategy : int {
427 /// Nothing decided yet
429 /// Candidate for rewriting IN(subquery) to EXISTS, or subquery
430 /// materialization
432 /// Candidate for semi-join flattening
434 /// Candidate for rewriting to joined derived table
436 /// Semi-join flattening
437 SEMIJOIN,
438 /// Rewrite to joined derived table
440 /// Evaluate as EXISTS subquery (possibly after rewriting from another type)
442 /// Subquery materialization (HASH_SJ_ENGINE)
444 /// Subquery has been deleted, probably because it was always false
445 DELETED,
446};
447
450
451 public:
452 /**
453 Create an Item that represents an EXISTS subquery predicate, or any
454 quantified comparison predicate that uses the same base class.
455
456 @param query_block First query block of query expression representing
457 the contained subquery.
458 */
459 explicit Item_exists_subselect(Query_block *query_block);
460
462
463 explicit Item_exists_subselect(const POS &pos) : super(pos) {}
464
465 // The left-hand expression of the subquery predicate. Unused with EXISTS
466 Item *left_expr{nullptr};
467
468 /// Priority of this predicate in the convert-to-semi-join-nest process.
470 /// Execution strategy chosen for this Item
472 /// Used by the transformation to derived table
474
475 /**
476 Used by subquery optimizations to keep track about where this subquery
477 predicate is located, and whether it is a candidate for transformation.
478 (Table_ref*) 1 - the predicate is an AND-part of the WHERE
479 join nest pointer - the predicate is an AND-part of ON expression
480 of a join nest
481 NULL - for all other locations. It also means that the
482 predicate is not a candidate for transformation.
483 See also THD::emb_on_expr_nest.
484
485 As for the second case above (the join nest pointer), note that this value
486 may change if scalar subqueries are transformed to derived tables,
487 cf. transform_scalar_subqueries_to_join_with_derived, due to the need to
488 build new join nests. The change is performed in Query_block::nest_derived.
489 */
491
493
494 /*
495 Transform subquery predicate to a form that can be executed, e.g.
496 as an EXISTS subquery, or a MAX or MIN aggregation on the subquery.
497
498 This is a virtual function that has implementations for EXISTS, IN
499 and quantified comparison subquery predicates.
500
501 @param thd Thread handle
502 @param[out] transformed Points to transformed representation of the object
503 if unchanged: No transformation was performed
504
505 @returns false if success, true if error
506 */
507 virtual bool transformer(THD *thd, Item **transformed);
508
509 Subquery_type subquery_type() const override { return EXISTS_SUBQUERY; }
510 bool is_bool_func() const override { return true; }
511 void reset() override {
513 m_value = false;
514 }
515
516 enum Item_result result_type() const override { return INT_RESULT; }
517 /*
518 The item is
519 ([NOT] IN/EXISTS) [ IS [NOT] TRUE|FALSE ]
520 */
522 bool with_is_op() const {
523 switch (value_transform) {
524 case BOOL_IS_TRUE:
525 case BOOL_IS_FALSE:
526 case BOOL_NOT_TRUE:
527 case BOOL_NOT_FALSE:
528 return true;
529 default:
530 return false;
531 }
532 }
533 /// True if the IS TRUE/FALSE wasn't explicit in the query
534 bool implicit_is_op = false;
535 Item *truth_transformer(THD *, enum Bool_test test) override;
536 bool translate(bool &null_v, bool v);
537 void apply_is_true() override {
538 const bool had_is = with_is_op();
540 if (!had_is && value_transform == BOOL_IS_TRUE)
541 implicit_is_op = true; // needn't be written by EXPLAIN
542 }
543 /// True if the Item has decided that it can do antijoin
544 bool can_do_aj = false;
546 bool fix_fields(THD *thd, Item **ref) override;
547 longlong val_int() override;
548 double val_real() override;
549 String *val_str(String *) override;
550 my_decimal *val_decimal(my_decimal *) override;
551 bool val_bool() override;
552 bool get_date(MYSQL_TIME *ltime, my_time_flags_t fuzzydate) override {
553 return get_date_from_int(ltime, fuzzydate);
554 }
555 bool get_time(MYSQL_TIME *ltime) override { return get_time_from_int(ltime); }
556 bool resolve_type(THD *thd) override;
557 void print(const THD *thd, String *str,
558 enum_query_type query_type) const override;
559
561
562 protected:
563 bool is_semijoin_candidate(THD *thd);
564 bool is_derived_candidate(THD *thd);
565
566 /// value of this item (boolean: exists/not-exists)
567 bool m_value{false};
568
569 /**
570 True if naked IN is allowed to exchange FALSE for UNKNOWN.
571 Because this is about the naked IN, there is no public ignore_unknown(),
572 intentionally, so that callers don't get it wrong.
573 */
574 bool abort_on_null{false};
575};
576
577/**
578 Representation of IN subquery predicates of the form
579 "left_expr IN (SELECT ...)".
580
581 @details
582 This class has:
583 - A "subquery execution engine" (as a subclass of Item_subselect) that allows
584 it to evaluate subqueries. (and this class participates in execution by
585 having m_was_null variable where part of execution result is stored.
586 - Transformation methods (todo: more on this).
587
588 This class is not used directly, it is "wrapped" into Item_in_optimizer
589 which provides some small bits of subquery evaluation.
590*/
591
594
595 public:
597 Item_in_subselect(const POS &pos, Item *left_expr,
598 PT_subquery *pt_subquery_arg);
599
601
602 bool do_itemize(Parse_context *pc, Item **res) override;
603
604 void cleanup() override;
605 Subquery_type subquery_type() const override { return IN_SUBQUERY; }
606
607 void reset() override {
608 m_value = false;
609 null_value = false;
610 m_was_null = false;
611 }
612 bool transformer(THD *thd, Item **transformed) override;
614 Item **transformed);
616 Item **transformed);
617 bool row_value_transformer(THD *thd, Item **transformed);
619 Comp_creator *func);
621 Item_in_optimizer *optimizer);
622 bool subquery_allows_materialization(THD *thd, Query_block *query_block,
623 const Query_block *outer);
624 bool walk(Item_processor processor, enum_walk walk, uchar *arg) override;
626 Item *compile(Item_analyzer analyzer, uchar **arg_p,
627 Item_transformer transformer, uchar *arg_t) override;
628
629 bool exec(THD *thd) override;
630 longlong val_int() override;
631 double val_real() override;
632 String *val_str(String *) override;
633 my_decimal *val_decimal(my_decimal *) override;
634 bool val_bool() override;
635 bool test_limit();
636 void print(const THD *thd, String *str,
637 enum_query_type query_type) const override;
638 void fix_after_pullout(Query_block *parent_query_block,
639 Query_block *removed_query_block) override;
640 void update_used_tables() override;
641 bool init_left_expr_cache(THD *thd);
642
643 /**
644 Once the decision to use IN->EXISTS has been taken, performs some last
645 steps of this transformation.
646 */
647 bool finalize_exists_transform(THD *thd, Query_block *select);
648 /**
649 Once the decision to use materialization has been taken, performs some
650 last steps of this transformation.
651 */
653 AccessPath *root_access_path() const override;
654 std::optional<ContainedSubquery> get_contained_subquery(
655 const Query_block *outer_query_block) override;
656
658 return m_in2exists_info != nullptr && m_in2exists_info->added_to_where;
659 }
660
661 /// Is reliable only if IN->EXISTS has been done.
663 return m_in2exists_info->dependent_before;
664 }
665
666 bool *get_cond_guard(int i) const {
667 return m_pushed_cond_guards != nullptr ? m_pushed_cond_guards + i : nullptr;
668 }
669 void set_cond_guard_var(int i, bool v) const {
670 if (m_pushed_cond_guards != nullptr) m_pushed_cond_guards[i] = v;
671 }
672
675 friend class Item_in_optimizer;
678
679 /// Used to trigger on/off conditions that were pushed down to subquery
680 bool *m_pushed_cond_guards{nullptr};
681
682 /// Point on NOT/NOP before ALL/SOME subquery
684
685 protected:
686 /**
687 Cache of the left operand of the subquery predicate. Allocated in the
688 runtime memory root, for each execution, thus need not be freed.
689 */
691
692 /// Whether m_left_expr_cache holds a value
694
695 /// The need for expr cache may be optimized away, @sa init_left_expr_cache.
696 bool need_expr_cache{true};
697
698 private:
699 bool mark_as_outer(Item *left_row, size_t col);
700
701 /**
702 In the case of
703
704 x COMP_OP (SELECT1 UNION SELECT2 ...)
705
706 - the subquery transformation is done on SELECT1; this requires wrapping
707 'x' with more Item layers, and injecting that in a condition in SELECT1.
708
709 - the same transformation is done on SELECT2; but the wrapped 'x' doesn't
710 need to be created again, the one created for SELECT1 could be reused
711
712 - to achieve this, the wrapped 'x' is stored in member
713 'm_injected_left_expr' when it is created for SELECT1, and is later
714 reused for SELECT2.
715
716 This will refer to a cached value which is reevaluated once for each
717 candidate row, cf. setup in #single_value_transformer.
718 */
720
721 bool m_was_null{false};
722
723 /**
724 This bundles several pieces of information useful when doing the
725 IN->EXISTS transform. If this transform has not been done, pointer is
726 NULL.
727 */
729 /**
730 True: if IN->EXISTS has been done and has added a condition to the
731 subquery's WHERE clause.
732 */
734 /**
735 True: if subquery was dependent (correlated) before IN->EXISTS
736 was done.
737 */
739 /**
740 True: if subquery was dependent (correlated) after IN->EXISTS
741 was done.
742 */
744 } *m_in2exists_info{nullptr};
745
747
748 bool val_bool_naked();
749};
750
751/**
752 Class that represents a quantified comparison predicate.
753
754 expression comp-op ANY ( subquery )
755 expression comp-op ALL ( subquery )
756
757 Note that the special cases = ANY (aka IN) and <> ALL (aka NOT IN)
758 are handled by the base class Item_in_subselect.
759*/
761 public:
763 Query_block *select, bool all);
764
765 Subquery_type subquery_type() const override {
767 }
768 bool transformer(THD *thd, Item **transformed) override;
769 void print(const THD *thd, String *str,
770 enum_query_type query_type) const override;
771
774 bool m_all;
775};
776
777/**
778 A subquery execution engine that evaluates the subquery by doing index
779 lookups in a single table's index.
780
781 This engine is used to resolve subqueries in forms
782
783 outer_expr IN (SELECT tbl.key FROM tbl WHERE subq_where)
784
785 or, row-based:
786
787 (oe1, .. oeN) IN (SELECT key_part1, ... key_partK
788 FROM tbl WHERE subqwhere)
789
790 i.e. the subquery is a single table SELECT without GROUP BY, aggregate
791 functions, etc.
792*/
794 protected:
795 Query_result_union *result = nullptr; /* results storage class */
796 /// Table which is read, using one of eq_ref, ref, ref_or_null.
797 TABLE *table{nullptr};
801 Item *m_cond; ///< The WHERE condition of the subquery
802 ulonglong m_hash; ///< Hash value calculated by RefIterator, when needed.
803 /*
804 The "having" clause. This clause (further referred to as "artificial
805 having") was inserted by subquery transformation code. It contains
806 Item(s) that have a side-effect: they record whether the subquery has
807 produced a row with NULL certain components. We need to use it for cases
808 like
809 (oe1, oe2) IN (SELECT t.key, t.no_key FROM t1)
810 where we do index lookup on t.key=oe1 but need also to check if there
811 was a row such that t.no_key IS NULL.
812 */
814
815 Item_in_subselect *item; /* item that uses this engine */
816
817 public:
819
821 const Index_lookup &ref,
822 enum join_type join_type,
824 Item *having)
825 : table(table),
827 ref(ref),
829 m_cond(where),
830 m_having(having),
831 item(subs) {}
833 virtual bool exec(THD *thd);
834 virtual void print(const THD *thd, String *str, enum_query_type query_type);
836 virtual void cleanup() {}
837 virtual void create_iterators(THD *) {}
838};
839
840/*
841 This function is actually defined in sql_parse.cc, but it depends on
842 chooser_compare_func_creator defined in this file.
843 */
846 Query_block *select);
847
848/**
849 Compute an IN predicate via a hash semi-join. The subquery is materialized
850 during the first evaluation of the IN predicate. The IN predicate is executed
851 via the functionality inherited from subselect_indexsubquery_engine.
852*/
853
855 private:
856 /* true if the subquery was materialized into a temp table. */
858 // true if we know for sure that there are zero rows in the table.
859 // Set only after is_materialized is true.
860 bool has_zero_rows = false;
861 /**
862 Existence of inner NULLs in materialized table:
863 By design, other values than IRRELEVANT_OR_FALSE are possible only if the
864 subquery has only one inner expression.
865 */
867 /// none, or they don't matter
869 /// they matter, and we don't know yet if they exists
871 /// they matter, and we know there exists at least one.
872 NEX_TRUE = 2
873 };
878
879 /// Saved result object, must be restored after use
881
882 public:
884 Query_expression *query_expr)
886 in_predicate, nullptr, nullptr),
887 is_materialized(false),
888 m_query_expr(query_expr) {}
889 ~subselect_hash_sj_engine() override;
890
891 bool setup(THD *thd, const mem_root_deque<Item *> &tmp_columns);
892 void cleanup() override;
893 bool exec(THD *thd) override;
894 void print(const THD *thd, String *str, enum_query_type query_type) override;
895 enum_engine_type engine_type() const override { return HASH_SJ_ENGINE; }
896
897 TABLE *get_table() const { return table; }
898 const Index_lookup &index_lookup() const { return ref; }
899 enum join_type get_join_type() const { return type; }
901 void create_iterators(THD *thd) override;
902};
903
904/**
905 Removes every predicate injected by IN->EXISTS.
906
907 This function is different from others:
908 - it wants to remove all traces of IN->EXISTS (for
909 materialization)
910 - remove_subq_pushed_predicates() and remove_additional_cond() want to
911 remove only the conditions of IN->EXISTS which index lookup already
912 satisfies (they are just an optimization).
913
914 If there are no in2exists conditions, it will return the exact same
915 pointer. If it returns a new Item, the old Item is left alone, so it
916 can be reused in other settings.
917
918 @param conds Condition; may be nullptr.
919 @returns new condition
920 */
922
923/// @returns whether the item is a quantified comparison predicate
925
926#endif /* ITEM_SUBSELECT_INCLUDED */
Kerberos Client Authentication nullptr
Definition: auth_kerberos_client_plugin.cc:251
Abstract factory interface for creating comparison predicates.
Definition: item_cmpfunc.h:524
Definition: field.h:577
Class that represents a quantified comparison predicate.
Definition: item_subselect.h:760
Item_allany_subselect(Item *left_expr, chooser_compare_func_creator fc, Query_block *select, bool all)
Definition: item_subselect.cc:1451
bool transformer(THD *thd, Item **transformed) override
Definition: item_subselect.cc:2917
bool m_all
Definition: item_subselect.h:774
Subquery_type subquery_type() const override
Definition: item_subselect.h:765
Comp_creator * m_func
Definition: item_subselect.h:773
void print(const THD *thd, String *str, enum_query_type query_type) const override
This method is used for to:
Definition: item_subselect.cc:2927
chooser_compare_func_creator m_func_creator
Definition: item_subselect.h:772
Definition: item.h:6800
Definition: item_subselect.h:448
enum_condition_context outer_condition_context
Used by the transformation to derived table.
Definition: item_subselect.h:473
bool is_semijoin_candidate(THD *thd)
Definition: item_subselect.cc:1507
void apply_is_true() override
Apply the IS TRUE truth property, meaning that an UNKNOWN result and a FALSE result are treated the s...
Definition: item_subselect.h:537
bool resolve_type(THD *thd) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_subselect.cc:1468
bool get_date(MYSQL_TIME *ltime, my_time_flags_t fuzzydate) override
Definition: item_subselect.h:552
String * val_str(String *) override
Return the result of EXISTS as a string value.
Definition: item_subselect.cc:1716
bool m_value
value of this item (boolean: exists/not-exists)
Definition: item_subselect.h:567
Item_exists_subselect()
Definition: item_subselect.h:461
double val_real() override
Definition: item_subselect.cc:1702
bool get_time(MYSQL_TIME *ltime) override
Definition: item_subselect.h:555
bool implicit_is_op
True if the IS TRUE/FALSE wasn't explicit in the query.
Definition: item_subselect.h:534
Item * truth_transformer(THD *, enum Bool_test test) override
Informs an item that it is wrapped in a truth test, in case it wants to transforms itself to implemen...
Definition: item_subselect.cc:1379
longlong val_int() override
Definition: item_subselect.cc:1704
Subquery_strategy strategy
Execution strategy chosen for this Item.
Definition: item_subselect.h:471
Item * left_expr
Definition: item_subselect.h:466
bool val_bool() override
Definition: item_subselect.cc:1740
int sj_convert_priority
Priority of this predicate in the convert-to-semi-join-nest process.
Definition: item_subselect.h:469
void reset() override
Reset state after a single execution of a subquery, useful when a dependent subquery must be evaluate...
Definition: item_subselect.h:511
void print(const THD *thd, String *str, enum_query_type query_type) const override
This method is used for to:
Definition: item_subselect.cc:1321
bool abort_on_null
True if naked IN is allowed to exchange FALSE for UNKNOWN.
Definition: item_subselect.h:574
virtual bool transformer(THD *thd, Item **transformed)
Definition: item_subselect.cc:1490
bool is_derived_candidate(THD *thd)
Definition: item_subselect.cc:1598
bool can_do_aj
True if the Item has decided that it can do antijoin.
Definition: item_subselect.h:544
bool with_is_op() const
Definition: item_subselect.h:522
bool fix_fields(THD *thd, Item **ref) override
An object of class Item_in_subselect is always substituted with another object of class Item_in_optim...
Definition: item_subselect.cc:2656
enum Bool_test value_transform
Definition: item_subselect.h:521
void notify_removal() override
Called when an item has been removed, can be used to notify external objects about the removal,...
Definition: item_subselect.h:492
Subquery_type subquery_type() const override
Definition: item_subselect.h:509
Item_subselect super
Definition: item_subselect.h:449
bool translate(bool &null_v, bool v)
Translates the value of the naked EXISTS to a value taking into account the optional NULL and IS [NOT...
Definition: item_subselect.cc:1342
bool is_bool_func() const override
Definition: item_subselect.h:510
Table_ref * embedding_join_nest
Used by subquery optimizations to keep track about where this subquery predicate is located,...
Definition: item_subselect.h:490
bool choose_semijoin_or_antijoin()
Helper for is_semijoin_candidate() and is_derived_candidate().
Definition: item_subselect.cc:1665
Item_exists_subselect(const POS &pos)
Definition: item_subselect.h:463
my_decimal * val_decimal(my_decimal *) override
Return the result of EXISTS as a decimal value.
Definition: item_subselect.cc:1733
enum Item_result result_type() const override
Definition: item_subselect.h:516
Definition: item_cmpfunc.h:924
Definition: item_cmpfunc.h:491
Representation of IN subquery predicates of the form "left_expr IN (SELECT ...)".
Definition: item_subselect.h:592
void fix_after_pullout(Query_block *parent_query_block, Query_block *removed_query_block) override
Definition: item_subselect.cc:2726
my_decimal * val_decimal(my_decimal *) override
Return the result of EXISTS as a decimal value.
Definition: item_subselect.cc:1793
Item * compile(Item_analyzer analyzer, uchar **arg_p, Item_transformer transformer, uchar *arg_t) override
Perform a generic "compilation" of the Item tree, ie transform the Item tree by adding zero or more I...
Definition: item_subselect.cc:769
double val_real() override
Definition: item_subselect.cc:1751
struct Item_in_subselect::In2exists_info nullptr
bool m_left_expr_cache_filled
Whether m_left_expr_cache holds a value.
Definition: item_subselect.h:693
bool single_value_transformer(THD *thd, Comp_creator *func, Item **transformed)
Transform a single-column IN/ALL/ANY subquery predicate.
Definition: item_subselect.cc:1829
void set_cond_guard_var(int i, bool v) const
Definition: item_subselect.h:669
bool row_value_transformer(THD *thd, Item **transformed)
Transform a multi-column IN/ALL/ANY subquery predicate.
Definition: item_subselect.cc:2258
std::optional< ContainedSubquery > get_contained_subquery(const Query_block *outer_query_block) override
If this item represents a IN/ALL/ANY/comparison_operator subquery, return that (along with data on ho...
Definition: item_subselect.cc:2784
Item_func_not_all * m_upper_item
Point on NOT/NOP before ALL/SOME subquery.
Definition: item_subselect.h:683
bool need_expr_cache
The need for expr cache may be optimized away,.
Definition: item_subselect.h:696
bool finalize_materialization_transform(THD *thd, JOIN *join)
Once the decision to use materialization has been taken, performs some last steps of this transformat...
Definition: item_subselect.cc:481
bool do_itemize(Parse_context *pc, Item **res) override
The core function that does the actual itemization.
Definition: item_subselect.cc:1438
void print(const THD *thd, String *str, enum_query_type query_type) const override
This method is used for to:
Definition: item_subselect.cc:2614
void reset() override
Reset state after a single execution of a subquery, useful when a dependent subquery must be evaluate...
Definition: item_subselect.h:607
List< Cached_item > * m_left_expr_cache
Cache of the left operand of the subquery predicate.
Definition: item_subselect.h:690
bool mark_as_outer(Item *left_row, size_t col)
Decide whether to mark the injected left expression "outer" relative to the subquery.
Definition: item_subselect.cc:433
Item * transform(Item_transformer transformer, uchar *arg) override
Perform a generic transformation of the Item tree, by adding zero or more additional Item objects to ...
Definition: item_subselect.cc:762
bool * m_pushed_cond_guards
Used to trigger on/off conditions that were pushed down to subquery.
Definition: item_subselect.h:680
bool dependent_before_in2exists() const
Is reliable only if IN->EXISTS has been done.
Definition: item_subselect.h:662
AccessPath * root_access_path() const override
Definition: item_subselect.cc:572
PT_subquery * pt_subselect
Definition: item_subselect.h:746
longlong val_int() override
Definition: item_subselect.cc:1758
bool * get_cond_guard(int i) const
Definition: item_subselect.h:666
bool row_value_in_to_exists_transformer(THD *thd, Query_block *select, Item_in_optimizer *optimizer)
Transform a (possibly non-correlated) IN subquery into a correlated EXISTS.
Definition: item_subselect.cc:2323
bool finalize_exists_transform(THD *thd, Query_block *select)
Once the decision to use IN->EXISTS has been taken, performs some last steps of this transformation.
Definition: item_subselect.cc:440
bool val_bool() override
Definition: item_subselect.cc:1772
bool m_was_null
Definition: item_subselect.h:721
bool init_left_expr_cache(THD *thd)
Initialize the cache of the left operand of the IN predicate.
Definition: item_subselect.cc:2751
bool quantified_comp_transformer(THD *thd, Comp_creator *func, Item **transformed)
Perform transformation of quantified comparison predicates (ie.
Definition: item_subselect.cc:2533
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_subselect.cc:540
String * val_str(String *) override
Return the result of EXISTS as a string value.
Definition: item_subselect.cc:1765
void update_used_tables() override
Updates used tables, not null tables information and accumulates properties up the item tree,...
Definition: item_subselect.cc:2733
bool in2exists_added_to_where() const
Definition: item_subselect.h:657
bool walk(Item_processor processor, enum_walk walk, uchar *arg) override
Traverses a tree of Items in prefix and/or postfix order.
Definition: item_subselect.cc:756
Item_exists_subselect super
Definition: item_subselect.h:593
Subquery_type subquery_type() const override
Definition: item_subselect.h:605
bool single_value_in_to_exists_transformer(THD *thd, Query_block *select, Comp_creator *func)
Transform an IN predicate into EXISTS via predicate injection.
Definition: item_subselect.cc:2050
bool test_limit()
Definition: item_subselect.cc:1410
Item_in_subselect()
Definition: item_subselect.h:600
bool val_bool_naked()
Definition: item_subselect.cc:1779
Item_ref * m_injected_left_expr
In the case of.
Definition: item_subselect.h:719
bool exec(THD *thd) override
Definition: item_subselect.cc:785
bool transformer(THD *thd, Item **transformed) override
Definition: item_subselect.cc:2517
Definition: item_cmpfunc.h:2310
Definition: item_subselect.h:392
void print(const THD *thd, String *str, enum_query_type query_type) const override
This method is used for to:
Definition: item_subselect.cc:1109
bool m_has_values
Set if we have found at least one row.
Definition: item_subselect.h:414
bool is_maxmin() const override
Definition: item_subselect.h:410
bool m_max
True if performing MAX, false if MIN.
Definition: item_subselect.h:413
void reset_has_values() override
Used by max/min subquery to initialize value presence registration mechanism.
Definition: item_subselect.h:409
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_subselect.cc:1102
bool has_values() const
Definition: item_subselect.h:407
void register_value()
Definition: item_subselect.h:408
Item_maxmin_subselect(Item_subselect *parent, Query_block *query_block, bool max_arg)
Create an Item for use in transformation of quantified comparison predicates that can be evaluated us...
Definition: item_subselect.cc:1086
Definition: item.h:6342
Definition: item.h:5894
Item with result field.
Definition: item.h:5829
Class that represents scalar subquery and row subquery.
Definition: item_subselect.h:273
Item * replace_scalar_subquery(uchar *arge) override
When walking the item tree seeing an Item_singlerow_subselect matching a target, replace it with a su...
Definition: item_subselect.cc:3016
enum Item_result result_type() const override
Definition: item_subselect.cc:1129
void store(uint i, Item *item)
Definition: item_subselect.cc:1120
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_subselect.cc:399
bool null_inside() override
Definition: item_subselect.cc:1183
Item ** addr(uint i) override
Definition: item_subselect.h:315
double val_real() override
Definition: item_subselect.cc:1197
bool resolve_type(THD *) override
Resolve type-related information for this item, such as result field type, maximum size,...
Definition: item_subselect.cc:1134
void no_rows_in_result() override
Definition: item_subselect.cc:1166
bool val_json(Json_wrapper *result) override
Get a JSON value from an Item.
Definition: item_subselect.cc:1242
Item_cache ** m_row
Value cache for a row or scalar subquery.
Definition: item_subselect.h:387
bool m_no_rows
no_rows_in_result
Definition: item_subselect.h:388
void reset() override
Reset state after a single execution of a subquery, useful when a dependent subquery must be evaluate...
Definition: item_subselect.cc:1115
Subquery_type subquery_type() const override
Definition: item_subselect.h:280
bool get_date(MYSQL_TIME *ltime, my_time_flags_t fuzzydate) override
Definition: item_subselect.cc:1253
std::optional< ContainedSubquery > get_contained_subquery(const Query_block *outer_query_block) override
If this item represents a IN/ALL/ANY/comparison_operator subquery, return that (along with data on ho...
Definition: item_subselect.cc:3074
longlong val_int() override
Definition: item_subselect.cc:1208
uint cols() const override
Definition: item_subselect.cc:3296
virtual bool is_maxmin() const
Definition: item_subselect.h:321
bool is_single_column_scalar_subquery() const override
Definition: item_subselect.cc:1125
bool fix_fields(THD *thd, Item **ref) override
Definition: item_subselect.cc:330
Item * element_index(uint i) override
Definition: item_subselect.h:314
Item_singlerow_subselect()
Definition: item_subselect.h:276
Query_block * invalidate_and_restore_query_block()
This method is used to implement a special case of semantic tree rewriting, mandated by a SQL:2003 ex...
Definition: item_subselect.cc:901
bool collect_scalar_subqueries(uchar *) override
Definition: item_subselect.cc:2941
bool get_time(MYSQL_TIME *ltime) override
Definition: item_subselect.cc:1265
String * val_str(String *) override
Definition: item_subselect.cc:1219
bool val_bool() override
Definition: item_subselect.cc:1276
void bring_value() override
Definition: item_subselect.cc:1190
bool create_row(const mem_root_deque< Item * > &item_list, Item_cache **row, bool possibly_empty)
Makes storage for the output values for a scalar or row subquery and calculates their data and column...
Definition: item_subselect.cc:3195
bool check_cols(uint c) override
Definition: item_subselect.cc:1175
my_decimal * val_decimal(my_decimal *) override
Definition: item_subselect.cc:1230
Item_cache * m_value
Value cache of a scalar subquery.
Definition: item_subselect.h:381
Base class that is common to all subqueries and subquery predicates.
Definition: item_subselect.h:80
subselect_indexsubquery_engine * indexsubquery_engine
Only relevant for Item_in_subselect; optimized structure used for execution in place of running the e...
Definition: item_subselect.h:235
Item * replace_item_view_ref(uchar *arg) override
Transform processor.
Definition: item_subselect.cc:3179
void set_value_assigned()
Definition: item_subselect.h:146
bool clean_up_after_removal(uchar *arg) override
Clean up after removing the subquery from the item tree.
Definition: item_subselect.cc:2877
bool is_evaluated() const
Definition: item_subselect.cc:2923
enum_parsing_context m_parsing_place
where subquery is placed
Definition: item_subselect.h:245
bool collect_subqueries(uchar *) override
Definition: item_subselect.cc:2910
table_map used_tables() const override
Definition: item_subselect.h:154
void accumulate_expression(Item *item)
Accumulate properties from a selected expression within a query block.
Definition: item_subselect.cc:264
void accumulate_used_tables(table_map add_tables)
Accumulate used tables.
Definition: item_subselect.h:113
Query_expression * m_query_expr
The query expression of the subquery.
Definition: item_subselect.h:228
virtual Subquery_type subquery_type() const =0
bool check_function_as_value_generator(uchar *args) override
Check if this item is allowed for a virtual column or inside a default expression.
Definition: item_subselect.h:190
table_map subquery_used_tables() const
Definition: item_subselect.h:157
bool is_uncacheable() const
Definition: item_subselect.cc:3301
void accumulate_properties()
Accumulate properties from underlying query expression.
Definition: item_subselect.cc:200
virtual bool exec(THD *thd)
Definition: item_subselect.cc:663
Query_expression * query_expr() const
Definition: item_subselect.h:84
enum_engine_type
Definition: item_subselect.h:93
@ INDEXSUBQUERY_ENGINE
Definition: item_subselect.h:93
@ HASH_SJ_ENGINE
Definition: item_subselect.h:93
@ OTHER_ENGINE
Definition: item_subselect.h:93
void print(const THD *thd, String *str, enum_query_type query_type) const override
This method is used for to:
Definition: item_subselect.cc:861
Subquery_type
Definition: item_subselect.h:104
@ ALL_SUBQUERY
comp-op ALL quantified comparison predicate
Definition: item_subselect.h:108
@ IN_SUBQUERY
[NOT] IN subquery predicate
Definition: item_subselect.h:107
@ SCALAR_SUBQUERY
Scalar or row subquery.
Definition: item_subselect.h:105
@ ANY_SUBQUERY
comp-op ANY quantified comparison predicate
Definition: item_subselect.h:109
@ EXISTS_SUBQUERY
[NOT] EXISTS subquery predicate
Definition: item_subselect.h:106
bool explain_subquery_checker(uchar **arg) override
Register subquery to the table where it is used within a condition.
Definition: item_subselect.cc:656
bool m_value_assigned
True if value has been assigned to subquery.
Definition: item_subselect.h:261
Item * get_tmp_table_item(THD *thd) override
If an Item is materialized in a temporary table, a different Item may have to be used in the part of ...
Definition: item_subselect.cc:840
enum_parsing_context place()
Definition: item_subselect.h:183
virtual void reset()
Reset state after a single execution of a subquery, useful when a dependent subquery must be evaluate...
Definition: item_subselect.h:141
Item * replace_item_field(uchar *arg) override
Transform processor.
Definition: item_subselect.cc:3169
join_type get_join_type() const
Definition: item_subselect.cc:310
int in_cond_of_tab
If !=NO_PLAN_IDX: this Item is in the condition attached to the JOIN_TAB having this index in the par...
Definition: item_subselect.h:90
void accumulate_condition(Item *item)
Accumulate properties from a condition or GROUP/ORDER within a query block.
Definition: item_subselect.cc:275
virtual AccessPath * root_access_path() const
Definition: item_subselect.h:102
void create_iterators(THD *thd)
Definition: item_subselect.cc:280
void cleanup() override
Called for every Item after use (preparation and execution).
Definition: item_subselect.cc:315
Query_result_interceptor * m_query_result
The query result object associated with the query expression.
Definition: item_subselect.h:231
table_map m_subquery_used_tables
cache of used tables from subquery only (not including LHS of IN subquery)
Definition: item_subselect.h:240
const TABLE * get_table() const
Definition: item_subselect.cc:300
enum Type type() const override
Definition: item_subselect.cc:838
bool fix_fields(THD *thd, Item **ref) override
Definition: item_subselect.cc:593
void set_indexsubquery_engine(subselect_indexsubquery_engine *eng)
Definition: item_subselect.h:163
void bind(Query_expression *qe)
Bind this subquery object with the supplied query expression.
Definition: item_subselect.cc:144
void reset_value_assigned()
Definition: item_subselect.h:147
bool contains_outer_references() const
Return whether this subquery references any tables in the directly containing query block,...
Definition: item_subselect.h:121
table_map not_null_tables() const override
Return table map of tables that can't be NULL tables (tables that are used in a context where if they...
Definition: item_subselect.h:155
void update_used_tables() override
Updates used tables, not null tables information and accumulates properties up the item tree,...
Definition: item_subselect.cc:852
bool walk(Item_processor processor, enum_walk walk, uchar *arg) override
Traverses a tree of Items in prefix and/or postfix order.
Definition: item_subselect.cc:635
Item_subselect()
Definition: item_subselect.h:216
bool is_null() override
The method allows to determine nullness of a complex expression without fully evaluating it,...
Definition: item_subselect.h:149
const Index_lookup & index_lookup() const
Definition: item_subselect.cc:305
enum_engine_type engine_type() const
Definition: item_subselect.cc:286
bool is_value_assigned() const
Definition: item_subselect.h:145
Item_result_field super
Definition: item_subselect.h:81
bool m_traced_before
Whether or not execution of this subquery has been traced by optimizer tracing already.
Definition: item_subselect.h:268
bool inform_item_in_cond_of_tab(uchar *arg) override
Tells an Item that it is in the condition of a JOIN_TAB of a query block.
Definition: item_subselect.cc:2849
virtual void reset_has_values()
Used by max/min subquery to initialize value presence registration mechanism.
Definition: item_subselect.h:178
bool subq_opt_away_processor(uchar *arg) override
Mark the subquery as optimized away, for EXPLAIN.
Definition: item_subselect.cc:2861
uint m_max_columns
allowed number of columns (1 for scalar subqueries)
Definition: item_subselect.h:243
virtual bool is_single_column_scalar_subquery() const
Definition: item_subselect.h:132
void fix_after_pullout(Query_block *parent_query_block, Query_block *removed_query_block) override
Definition: item_subselect.cc:736
Item_subselect(const POS &pos)
Definition: item_subselect.h:217
table_map m_used_tables_cache
cache of used tables
Definition: item_subselect.h:238
Base class that is used to represent any kind of expression in a relational query.
Definition: item.h:930
void set_subquery()
Set the "has subquery" property.
Definition: item.h:3440
bool null_value
True if item is null.
Definition: item.h:3712
Type
Definition: item.h:965
Bool_test
< Modifier for result transformation
Definition: item.h:1008
@ BOOL_NOT_FALSE
Definition: item.h:1013
@ BOOL_NOT_TRUE
Definition: item.h:1012
@ BOOL_IS_TRUE
Definition: item.h:1009
@ BOOL_IS_FALSE
Definition: item.h:1010
@ BOOL_IDENTITY
Definition: item.h:1015
bool get_date_from_int(MYSQL_TIME *ltime, my_time_flags_t flags)
Convert val_int() to date in MYSQL_TIME.
Definition: item.cc:1589
bool update_null_value()
Make sure the null_value member has a correct value.
Definition: item.cc:7526
bool get_time_from_int(MYSQL_TIME *ltime)
Convert val_int() to time in MYSQL_TIME.
Definition: item.cc:1676
Definition: sql_optimizer.h:133
Abstraction for accessing JSON values irrespective of whether they are (started out as) binary JSON v...
Definition: json_dom.h:1150
Definition: sql_list.h:494
Definition: parse_tree_nodes.h:1773
Base class for parse tree nodes (excluding the Parse_tree_root hierarchy)
Definition: parse_tree_node_base.h:231
This class represents a query block, aka a query specification, which is a query consisting of a SELE...
Definition: sql_lex.h:1159
This class represents a query expression (one query block or several query blocks combined with UNION...
Definition: sql_lex.h:627
Definition: item_subselect.cc:1287
Definition: query_result.h:181
Query result class for scalar and row subqueries.
Definition: item_subselect.cc:107
Base class for result from a subquery.
Definition: query_result.h:312
Definition: sql_union.h:40
Using this class is fraught with peril, and you need to be very careful when doing so.
Definition: sql_string.h:167
For each client connection we create a separate thread with THD serving as a thread/connection descri...
Definition: sql_lexer_thd.h:36
Definition: table.h:2900
Object containing parameters used when creating and using temporary tables.
Definition: temp_table_param.h:97
A (partial) implementation of std::deque allocating its blocks on a MEM_ROOT.
Definition: mem_root_deque.h:111
my_decimal class limits 'decimal_t' type to what we need in MySQL.
Definition: my_decimal.h:96
Compute an IN predicate via a hash semi-join.
Definition: item_subselect.h:854
void create_iterators(THD *thd) override
Definition: item_subselect.cc:3539
void print(const THD *thd, String *str, enum_query_type query_type) override
Print the state of this engine into a string for debugging and views.
Definition: item_subselect.cc:3772
nulls_exist
Existence of inner NULLs in materialized table: By design, other values than IRRELEVANT_OR_FALSE are ...
Definition: item_subselect.h:866
@ NEX_TRUE
they matter, and we know there exists at least one.
Definition: item_subselect.h:872
@ NEX_UNKNOWN
they matter, and we don't know yet if they exists
Definition: item_subselect.h:870
@ NEX_IRRELEVANT_OR_FALSE
none, or they don't matter
Definition: item_subselect.h:868
void cleanup() override
Cleanup performed after each execution.
Definition: item_subselect.cc:3617
unique_ptr_destroy_only< RowIterator > m_iterator
Definition: item_subselect.h:876
subselect_hash_sj_engine(Item_in_subselect *in_predicate, Query_expression *query_expr)
Definition: item_subselect.h:883
TABLE * get_table() const
Definition: item_subselect.h:897
~subselect_hash_sj_engine() override
Definition: item_subselect.cc:3606
Query_result_interceptor * saved_result
Saved result object, must be restored after use.
Definition: item_subselect.h:880
enum nulls_exist mat_table_has_nulls
Definition: item_subselect.h:874
bool is_materialized
Definition: item_subselect.h:857
Query_expression *const m_query_expr
Definition: item_subselect.h:875
bool has_zero_rows
Definition: item_subselect.h:860
const Index_lookup & index_lookup() const
Definition: item_subselect.h:898
bool exec(THD *thd) override
Execute a subquery IN predicate via materialization.
Definition: item_subselect.cc:3652
enum_engine_type engine_type() const override
Definition: item_subselect.h:895
AccessPath * root_access_path() const
Definition: item_subselect.h:900
bool setup(THD *thd, const mem_root_deque< Item * > &tmp_columns)
Create all structures needed for subquery execution using hash semijoin.
Definition: item_subselect.cc:3369
enum join_type get_join_type() const
Definition: item_subselect.h:899
AccessPath * m_root_access_path
Definition: item_subselect.h:877
A subquery execution engine that evaluates the subquery by doing index lookups in a single table's in...
Definition: item_subselect.h:793
Item * m_cond
The WHERE condition of the subquery.
Definition: item_subselect.h:801
TABLE * table
Table which is read, using one of eq_ref, ref, ref_or_null.
Definition: item_subselect.h:797
virtual ~subselect_indexsubquery_engine()=default
virtual void cleanup()
Definition: item_subselect.h:836
virtual bool exec(THD *thd)
Definition: item_subselect.cc:3285
virtual void print(const THD *thd, String *str, enum_query_type query_type)
Definition: item_subselect.cc:3305
virtual void create_iterators(THD *)
Definition: item_subselect.h:837
Item * m_having
Definition: item_subselect.h:813
join_type type
Definition: item_subselect.h:800
enum_engine_type
Definition: item_subselect.h:818
@ HASH_SJ_ENGINE
Definition: item_subselect.h:818
@ INDEXSUBQUERY_ENGINE
Definition: item_subselect.h:818
Index_lookup ref
Definition: item_subselect.h:799
subselect_indexsubquery_engine(TABLE *table, Table_ref *table_ref, const Index_lookup &ref, enum join_type join_type, Item_in_subselect *subs, Item *where, Item *having)
Definition: item_subselect.h:820
ulonglong m_hash
Hash value calculated by RefIterator, when needed.
Definition: item_subselect.h:802
virtual enum_engine_type engine_type() const
Definition: item_subselect.h:835
Item_in_subselect * item
Definition: item_subselect.h:815
Table_ref * table_ref
Definition: item_subselect.h:798
Comp_creator *(*)(bool invert) chooser_compare_func_creator
Convenience typedef for a function that returns factories for Item comparators (ie....
Definition: comp_creator.h:39
static int cmp(Bigint *a, Bigint *b)
Definition: dtoa.cc:1064
enum_query_type
Query type constants (usable as bitmap flags).
Definition: enum_query_type.h:31
This file contains the field type.
bool subquery_allows_materialization(THD *thd, Query_block *query_block, const Query_block *outer)
Check if the subquery predicate can be executed via materialization.
Definition: sql_resolver.cc:1051
Item * all_any_subquery_creator(Item *left_expr, chooser_compare_func_creator cmp, bool all, Query_block *select)
Construct ALL/ANY/SOME subquery Item.
Definition: sql_parse.cc:6664
bool(Item::* Item_analyzer)(uchar **argp)
Definition: item.h:712
Item *(Item::* Item_transformer)(uchar *arg)
Type for transformers used by Item::transform and Item::compile.
Definition: item.h:721
Item * remove_in2exists_conds(Item *conds)
Removes every predicate injected by IN->EXISTS.
Definition: item_subselect.cc:465
Subquery_strategy
Classes that represent predicates over table subqueries: [NOT] EXISTS, [NOT] IN, ANY/SOME and ALL.
Definition: item_subselect.h:426
@ CANDIDATE_FOR_SEMIJOIN
Candidate for semi-join flattening.
@ UNSPECIFIED
Nothing decided yet.
@ SUBQ_EXISTS
Evaluate as EXISTS subquery (possibly after rewriting from another type)
@ DERIVED_TABLE
Rewrite to joined derived table.
@ DELETED
Subquery has been deleted, probably because it was always false.
@ CANDIDATE_FOR_IN2EXISTS_OR_MAT
Candidate for rewriting IN(subquery) to EXISTS, or subquery materialization.
@ SEMIJOIN
Semi-join flattening.
@ SUBQ_MATERIALIZATION
Subquery materialization (HASH_SJ_ENGINE)
@ CANDIDATE_FOR_DERIVED_TABLE
Candidate for rewriting to joined derived table.
bool is_quantified_comp_predicate(Item *item)
Definition: item_subselect.cc:2816
This file follows Google coding style, except for the name MEM_ROOT (which is kept for historical rea...
std::unique_ptr< T, Destroy_only< T > > unique_ptr_destroy_only
std::unique_ptr, but only destroying.
Definition: my_alloc.h:480
Some integer typedefs for easier portability.
unsigned long long int ulonglong
Definition: my_inttypes.h:56
unsigned char uchar
Definition: my_inttypes.h:52
long long int longlong
Definition: my_inttypes.h:55
uint64_t table_map
Definition: my_table_map.h:30
Interface for low level time utilities.
unsigned int my_time_flags_t
Flags to str_to_datetime and number_to_datetime.
Definition: my_time.h:94
Time declarations shared between the server and client API: you should not add anything to this heade...
static char * where
Definition: mysqldump.cc:152
std::string str(const mysqlrouter::ConfigGenerator::Options::Endpoint &ep)
Definition: config_generator.cc:1105
PT & ref(PT *tp)
Definition: tablespace_impl.cc:359
std::string join(const detail::range auto &rng, std::string_view delim)
join elements of a range into a string separated by a delimiter.
Definition: string.h:74
int add_tables(PFS_engine_table_share_proxy **, unsigned int) noexcept
Definition: pfs_plugin_table_v1_all_empty.cc:33
enum_parsing_context
Names for different query parse tree parts.
Definition: parse_tree_node_base.h:61
@ CTX_NONE
Empty value.
Definition: parse_tree_node_base.h:62
File containing constants that can be used throughout the server.
constexpr const table_map PSEUDO_TABLE_BITS
Definition: sql_const.h:114
enum_walk
Enumeration for {Item,Query_block[_UNIT],Table_function}walk.
Definition: sql_const.h:289
bool(Item::*)(unsigned char *) Item_processor
Processor type for {Item,Query_block[_UNIT],Table_function}walk.
Definition: sql_const.h:307
enum_condition_context
Enumeration for Query_block::condition_context.
Definition: sql_const.h:313
Common types of the Optimizer, used by optimization and execution.
join_type
Definition: sql_opt_exec_shared.h:186
@ JT_UNKNOWN
Definition: sql_opt_exec_shared.h:188
#define NO_PLAN_IDX
undefined index
Definition: sql_opt_exec_shared.h:55
Access paths are a query planning structure that correspond 1:1 to iterators, in that an access path ...
Definition: access_path.h:227
Struct used to pass around arguments to/from check_function_as_value_generator.
Definition: item.h:488
int err_code
the error code found during check(if any)
Definition: item.h:495
int get_unnamed_function_error_code() const
Return the correct error code, based on whether or not if we are checking for disallowed functions in...
Definition: item.h:507
Structure used for index-based lookups.
Definition: sql_opt_exec_shared.h:67
This bundles several pieces of information useful when doing the IN->EXISTS transform.
Definition: item_subselect.h:728
bool added_to_where
True: if IN->EXISTS has been done and has added a condition to the subquery's WHERE clause.
Definition: item_subselect.h:733
bool dependent_before
True: if subquery was dependent (correlated) before IN->EXISTS was done.
Definition: item_subselect.h:738
bool dependent_after
True: if subquery was dependent (correlated) after IN->EXISTS was done.
Definition: item_subselect.h:743
Argument for walk method replace_scalar_subquery.
Definition: item_subselect.h:326
Query_block * m_outer_query_block
The immediately surrounding query block.
Definition: item_subselect.h:334
Field * m_field
The transformed query block.
Definition: item_subselect.h:332
TABLE * m_derived
the replacement field
Definition: item_subselect.h:330
Scalar_subquery_replacement(Item_singlerow_subselect *target, TABLE *derived, Field *field, Query_block *select, bool add_coalesce, bool add_having_compensation, uint having_idx)
Definition: item_subselect.h:347
Query_block * m_inner_query_block
True if subquery's selected item contains a COUNT aggregate.
Definition: item_subselect.h:337
bool m_add_coalesce
Presence of HAVING clause in subquery: Only relevant if m_add_coalesce is true.
Definition: item_subselect.h:339
Item_singlerow_subselect * m_target
< subquery to be replaced with ␓field from derived table
Definition: item_subselect.h:328
bool m_add_having_compensation
Index of field holding value of having clause in derived table's list of fields.
Definition: item_subselect.h:342
uint m_having_idx
Definition: item_subselect.h:345
argument used by walk method collect_scalar_subqueries ("css")
Definition: item_subselect.h:198
Collect_subq_info(Query_block *owner)
Definition: item_subselect.h:202
Query_block * m_query_block
Definition: item_subselect.h:201
std::vector< Item_subselect * > list
< accumulated all subq (or aggregates) found
Definition: item_subselect.h:200
bool contains(Query_expression *candidate)
Definition: item_subselect.h:203
Definition: mysql_time.h:82
Bison "location" class.
Definition: parse_location.h:43
Environment data for the contextualization phase.
Definition: parse_tree_node_base.h:420
Definition: table.h:1421
Definition: result.h:30
Item_result
Type of the user defined function return slot and arguments.
Definition: udf_registration_types.h:39
@ INT_RESULT
double
Definition: udf_registration_types.h:43
static int all(site_def const *s, node_no node)
Definition: xcom_transport.cc:885