MySQL 8.0.31
Source Code Documentation
table_esms_by_user_by_event_name.h
Go to the documentation of this file.
1/* Copyright (c) 2010, 2022, Oracle and/or its affiliates.
2
3 This program is free software; you can redistribute it and/or modify
4 it under the terms of the GNU General Public License, version 2.0,
5 as published by the Free Software Foundation.
6
7 This program is also distributed with certain software (including
8 but not limited to OpenSSL) that is licensed under separate terms,
9 as designated in a particular file or component or in included license
10 documentation. The authors of MySQL hereby grant you an additional
11 permission to link the program and your derivative works with the
12 separately licensed software that they have included with MySQL.
13
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License, version 2.0, for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
22 */
23
24#ifndef TABLE_ESMS_BY_USER_BY_EVENT_NAME_H
25#define TABLE_ESMS_BY_USER_BY_EVENT_NAME_H
26
27/**
28 @file storage/perfschema/table_esms_by_user_by_event_name.h
29 Table EVENTS_STATEMENTS_SUMMARY_BY_USER_BY_EVENT_NAME (declarations).
30*/
31
32#include <sys/types.h>
33
34#include "my_base.h"
37
38class Field;
39class Plugin_table;
40struct PFS_instr_class;
42struct PFS_user;
43struct TABLE;
44struct THR_LOCK;
45
46/**
47 @addtogroup performance_schema_tables
48 @{
49*/
50
52 public:
55 m_key_1("USER"),
56 m_key_2("EVENT_NAME") {}
57
59
60 virtual bool match(PFS_user *pfs);
61 virtual bool match(PFS_instr_class *instr_class);
62
63 private:
66};
67
68/**
69 A row of table
70 PERFORMANCE_SCHEMA.EVENTS_STATEMENTS_SUMMARY_BY_USER_BY_EVENT_NAME.
71*/
73 /** Column USER. */
75 /** Column EVENT_NAME. */
77 /** Columns COUNT_STAR, SUM/MIN/AVG/MAX TIMER_WAIT. */
79};
80
81/**
82 Position of a cursor on
83 PERFORMANCE_SCHEMA.EVENTS_STATEMENTS_SUMMARY_BY_USER_BY_EVENT_NAME.
84 Index 1 on user (0 based)
85 Index 2 on statement class (1 based)
86*/
89
90 inline void reset(void) {
91 m_index_1 = 0;
92 m_index_2 = 1;
93 }
94
95 inline void next_user(void) {
96 m_index_1++;
97 m_index_2 = 1;
98 }
99};
100
101/** Table PERFORMANCE_SCHEMA.EVENTS_STATEMENTS_SUMMARY_BY_USER_BY_EVENT_NAME. */
103 public:
104 /** Table share */
107 static int delete_all_rows();
108 static ha_rows get_row_count();
109
110 void reset_position(void) override;
111
112 int rnd_init(bool scan) override;
113 int rnd_next() override;
114 int rnd_pos(const void *pos) override;
115
116 int index_init(uint idx, bool sorted) override;
117 int index_next() override;
118
119 protected:
120 int read_row_values(TABLE *table, unsigned char *buf, Field **fields,
121 bool read_all) override;
122
124
125 public:
127
128 protected:
130
131 private:
132 /** Table share lock. */
134 /** Table definition. */
136
137 /** Current row. */
139 /** Current position. */
141 /** Next position. */
143
145};
146
147/** @} */
148#endif
Definition: field.h:574
Definition: pfs_engine_table.h:299
An abstract PERFORMANCE_SCHEMA table.
Definition: pfs_engine_table.h:69
Definition: table_esms_by_user_by_event_name.h:51
virtual bool match(PFS_user *pfs)
Definition: table_esms_by_user_by_event_name.cc:104
PFS_key_event_name m_key_2
Definition: table_esms_by_user_by_event_name.h:65
PFS_index_esms_by_user_by_event_name()
Definition: table_esms_by_user_by_event_name.h:53
PFS_key_user m_key_1
Definition: table_esms_by_user_by_event_name.h:64
~PFS_index_esms_by_user_by_event_name() override=default
Definition: table_helper.h:1431
Definition: table_helper.h:1446
Class to hold information regarding a table to be created on behalf of a plugin.
Definition: plugin_table.h:39
Table PERFORMANCE_SCHEMA.EVENTS_STATEMENTS_SUMMARY_BY_USER_BY_EVENT_NAME.
Definition: table_esms_by_user_by_event_name.h:102
static THR_LOCK m_table_lock
Table share lock.
Definition: table_esms_by_user_by_event_name.h:133
int index_init(uint idx, bool sorted) override
Definition: table_esms_by_user_by_event_name.cc:190
static ha_rows get_row_count()
Definition: table_esms_by_user_by_event_name.cc:138
int read_row_values(TABLE *table, unsigned char *buf, Field **fields, bool read_all) override
Read the current row values.
Definition: table_esms_by_user_by_event_name.cc:259
void reset_position(void) override
Reset the cursor position to the beginning of the table.
Definition: table_esms_by_user_by_event_name.cc:147
pos_esms_by_user_by_event_name m_pos
Current position.
Definition: table_esms_by_user_by_event_name.h:140
int rnd_init(bool scan) override
Initialize table scan.
Definition: table_esms_by_user_by_event_name.cc:152
pos_esms_by_user_by_event_name m_next_pos
Next position.
Definition: table_esms_by_user_by_event_name.h:142
table_esms_by_user_by_event_name()
Definition: table_esms_by_user_by_event_name.cc:142
static Plugin_table m_table_def
Table definition.
Definition: table_esms_by_user_by_event_name.h:135
int rnd_next() override
Fetch the next row in this cursor.
Definition: table_esms_by_user_by_event_name.cc:154
~table_esms_by_user_by_event_name() override=default
int make_row(PFS_user *user, PFS_statement_class *klass)
Definition: table_esms_by_user_by_event_name.cc:228
static PFS_engine_table_share m_share
Table share.
Definition: table_esms_by_user_by_event_name.h:105
static int delete_all_rows()
Definition: table_esms_by_user_by_event_name.cc:131
row_esms_by_user_by_event_name m_row
Current row.
Definition: table_esms_by_user_by_event_name.h:138
int rnd_pos(const void *pos) override
Fetch a row by position.
Definition: table_esms_by_user_by_event_name.cc:173
static PFS_engine_table * create(PFS_engine_table_share *)
Definition: table_esms_by_user_by_event_name.cc:126
int index_next() override
Find key in index, read record.
Definition: table_esms_by_user_by_event_name.cc:200
PFS_index_esms_by_user_by_event_name * m_opened_index
Definition: table_esms_by_user_by_event_name.h:144
char * pos
Definition: do_ctype.cc:76
This file includes constants used by all storage engines.
my_off_t ha_rows
Definition: my_base.h:1139
char * user
Definition: mysqladmin.cc:59
Definition: buf0block_hint.cc:29
Performance schema tables (declarations).
static const LEX_CSTRING pfs
Definition: sql_show_processlist.cc:65
Position of a double cursor, for iterations using 2 nested loops.
Definition: pfs_engine_table.h:593
uint m_index_1
Outer index.
Definition: pfs_engine_table.h:595
uint m_index_2
Current index within index_1.
Definition: pfs_engine_table.h:597
A PERFORMANCE_SCHEMA table share.
Definition: pfs_engine_table.h:357
Row fragment for column EVENT_NAME.
Definition: table_helper.h:581
Information for all instrumentation.
Definition: pfs_instr_class.h:204
Instrumentation metadata for a statement.
Definition: pfs_instr_class.h:554
Row fragment for statement statistics columns.
Definition: table_helper.h:845
Row fragment for column USER.
Definition: table_helper.h:538
Per user statistics.
Definition: pfs_user.h:62
Definition: table.h:1396
Definition: thr_lock.h:138
Position of a cursor on PERFORMANCE_SCHEMA.EVENTS_STATEMENTS_SUMMARY_BY_USER_BY_EVENT_NAME.
Definition: table_esms_by_user_by_event_name.h:87
void next_user(void)
Definition: table_esms_by_user_by_event_name.h:95
void reset(void)
Definition: table_esms_by_user_by_event_name.h:90
pos_esms_by_user_by_event_name()
Definition: table_esms_by_user_by_event_name.h:88
A row of table PERFORMANCE_SCHEMA.EVENTS_STATEMENTS_SUMMARY_BY_USER_BY_EVENT_NAME.
Definition: table_esms_by_user_by_event_name.h:72
PFS_statement_stat_row m_stat
Columns COUNT_STAR, SUM/MIN/AVG/MAX TIMER_WAIT.
Definition: table_esms_by_user_by_event_name.h:78
PFS_user_row m_user
Column USER.
Definition: table_esms_by_user_by_event_name.h:74
PFS_event_name_row m_event_name
Column EVENT_NAME.
Definition: table_esms_by_user_by_event_name.h:76
Helpers to implement a performance schema table.
unsigned int uint
Definition: uca-dump.cc:29