summaryrefslogtreecommitdiffstats
path: root/sql/item_vers.h
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 12:24:36 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 12:24:36 +0000
commit06eaf7232e9a920468c0f8d74dcf2fe8b555501c (patch)
treee2c7b5777f728320e5b5542b6213fd3591ba51e2 /sql/item_vers.h
parentInitial commit. (diff)
downloadmariadb-06eaf7232e9a920468c0f8d74dcf2fe8b555501c.tar.xz
mariadb-06eaf7232e9a920468c0f8d74dcf2fe8b555501c.zip
Adding upstream version 1:10.11.6.upstream/1%10.11.6
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'sql/item_vers.h')
-rw-r--r--sql/item_vers.h150
1 files changed, 150 insertions, 0 deletions
diff --git a/sql/item_vers.h b/sql/item_vers.h
new file mode 100644
index 00000000..88c8cea8
--- /dev/null
+++ b/sql/item_vers.h
@@ -0,0 +1,150 @@
+#ifndef ITEM_VERS_INCLUDED
+#define ITEM_VERS_INCLUDED
+/* Copyright (c) 2017, MariaDB Corporation.
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; version 2 of the License.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */
+
+
+/* System Versioning items */
+
+#ifdef USE_PRAGMA_INTERFACE
+#pragma interface /* gcc class implementation */
+#endif
+
+class Item_func_history: public Item_bool_func
+{
+public:
+ /*
+ @param a Item_field for row_end system field
+ */
+ Item_func_history(THD *thd, Item *a): Item_bool_func(thd, a)
+ {
+ DBUG_ASSERT(a->type() == Item::FIELD_ITEM);
+ }
+
+ bool val_bool() override;
+ longlong val_int() override { return val_bool(); }
+ bool fix_length_and_dec(THD *thd) override
+ {
+ set_maybe_null();
+ null_value= 0;
+ decimals= 0;
+ max_length= 1;
+ return FALSE;
+ }
+ LEX_CSTRING func_name_cstring() const override
+ {
+ static LEX_CSTRING name= {STRING_WITH_LEN("is_history") };
+ return name;
+ }
+ void print(String *str, enum_query_type query_type) override;
+ Item *get_copy(THD *thd) override
+ { return get_item_copy<Item_func_history>(thd, this); }
+};
+
+class Item_func_trt_ts: public Item_datetimefunc
+{
+ TR_table::field_id_t trt_field;
+public:
+ Item_func_trt_ts(THD *thd, Item* a, TR_table::field_id_t _trt_field);
+ LEX_CSTRING func_name_cstring() const override
+ {
+ static LEX_CSTRING begin_name= {STRING_WITH_LEN("trt_begin_ts") };
+ static LEX_CSTRING commit_name= {STRING_WITH_LEN("trt_commit_ts") };
+ return (trt_field == TR_table::FLD_BEGIN_TS) ? begin_name : commit_name;
+ }
+ bool get_date(THD *thd, MYSQL_TIME *res, date_mode_t fuzzydate) override;
+ Item *get_copy(THD *thd) override
+ { return get_item_copy<Item_func_trt_ts>(thd, this); }
+ bool fix_length_and_dec(THD *thd) override
+ { fix_attributes_datetime(decimals); return FALSE; }
+};
+
+class Item_func_trt_id : public Item_longlong_func
+{
+ TR_table::field_id_t trt_field;
+ bool backwards;
+
+ longlong get_by_trx_id(ulonglong trx_id);
+ longlong get_by_commit_ts(MYSQL_TIME &commit_ts, bool backwards);
+
+public:
+ Item_func_trt_id(THD *thd, Item* a, TR_table::field_id_t _trt_field, bool _backwards= false);
+ Item_func_trt_id(THD *thd, Item* a, Item* b, TR_table::field_id_t _trt_field);
+
+ LEX_CSTRING func_name_cstring() const override
+ {
+ static LEX_CSTRING trx_name= {STRING_WITH_LEN("trt_trx_id") };
+ static LEX_CSTRING commit_name= {STRING_WITH_LEN("trt_commit_id") };
+ static LEX_CSTRING iso_name= {STRING_WITH_LEN("trt_iso_level") };
+
+ switch (trt_field) {
+ case TR_table::FLD_TRX_ID:
+ return trx_name;
+ case TR_table::FLD_COMMIT_ID:
+ return commit_name;
+ case TR_table::FLD_ISO_LEVEL:
+ return iso_name;
+ default:
+ DBUG_ASSERT(0);
+ }
+ return NULL_clex_str;
+ }
+
+ bool fix_length_and_dec(THD *thd) override
+ {
+ bool res= Item_int_func::fix_length_and_dec(thd);
+ max_length= 20;
+ return res;
+ }
+
+ longlong val_int() override;
+ Item *get_copy(THD *thd) override
+ { return get_item_copy<Item_func_trt_id>(thd, this); }
+};
+
+class Item_func_trt_trx_sees : public Item_bool_func
+{
+protected:
+ bool accept_eq;
+
+public:
+ Item_func_trt_trx_sees(THD *thd, Item* a, Item* b);
+ LEX_CSTRING func_name_cstring() const override
+ {
+ static LEX_CSTRING name= {STRING_WITH_LEN("trt_trx_sees") };
+ return name;
+ }
+ longlong val_int() override;
+ Item *get_copy(THD *thd) override
+ { return get_item_copy<Item_func_trt_trx_sees>(thd, this); }
+};
+
+class Item_func_trt_trx_sees_eq :
+ public Item_func_trt_trx_sees
+{
+public:
+ Item_func_trt_trx_sees_eq(THD *thd, Item* a, Item* b) :
+ Item_func_trt_trx_sees(thd, a, b)
+ {
+ accept_eq= true;
+ }
+ LEX_CSTRING func_name_cstring() const override
+ {
+ static LEX_CSTRING name= {STRING_WITH_LEN("trt_trx_sees_eq") };
+ return name;
+ }
+};
+
+#endif /* ITEM_VERS_INCLUDED */