1/* Copyright (c) 2010, 2012, Oracle and/or its affiliates. All rights reserved.
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 as published by
5 the Free Software Foundation; version 2 of the License.
6
7 This program is distributed in the hope that it will be useful,
8 but WITHOUT ANY WARRANTY; without even the implied warranty of
9 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 GNU General Public License for more details.
11
12 You should have received a copy of the GNU General Public License
13 along with this program; if not, write to the Free Software
14 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */
15
16#ifndef TABLE_ESGS_BY_ACCOUNT_BY_EVENT_NAME_H
17#define TABLE_ESGS_BY_ACCOUNT_BY_EVENT_NAME_H
18
19/**
20 @file storage/perfschema/table_esgs_by_account_by_event_name.h
21 Table EVENTS_STAGES_SUMMARY_BY_ACCOUNT_BY_EVENT_NAME (declarations).
22*/
23
24#include "pfs_column_types.h"
25#include "pfs_engine_table.h"
26#include "pfs_instr_class.h"
27#include "pfs_instr.h"
28#include "pfs_account.h"
29#include "table_helper.h"
30
31/**
32 @addtogroup Performance_schema_tables
33 @{
34*/
35
36/**
37 A row of table
38 PERFORMANCE_SCHEMA.EVENTS_STAGES_SUMMARY_BY_ACCOUNT_BY_EVENT_NAME.
39*/
40struct row_esgs_by_account_by_event_name
41{
42 /** Column USER, HOST. */
43 PFS_account_row m_account;
44 /** Column EVENT_NAME. */
45 PFS_event_name_row m_event_name;
46 /** Columns COUNT_STAR, SUM/MIN/AVG/MAX TIMER_WAIT. */
47 PFS_stage_stat_row m_stat;
48};
49
50/**
51 Position of a cursor on
52 PERFORMANCE_SCHEMA.EVENTS_STAGES_SUMMARY_BY_ACCOUNT_BY_EVENT_NAME.
53 Index 1 on user@host (0 based)
54 Index 2 on stage class (1 based)
55*/
56struct pos_esgs_by_account_by_event_name
57: public PFS_double_index
58{
59 pos_esgs_by_account_by_event_name()
60 : PFS_double_index(0, 1)
61 {}
62
63 inline void reset(void)
64 {
65 m_index_1= 0;
66 m_index_2= 1;
67 }
68
69 inline bool has_more_account(void)
70 { return (m_index_1 < account_max); }
71
72 inline void next_account(void)
73 {
74 m_index_1++;
75 m_index_2= 1;
76 }
77};
78
79/** Table PERFORMANCE_SCHEMA.EVENTS_STAGES_SUMMARY_BY_ACCOUNT_BY_EVENT_NAME. */
80class table_esgs_by_account_by_event_name : public PFS_engine_table
81{
82public:
83 /** Table share */
84 static PFS_engine_table_share m_share;
85 static PFS_engine_table* create();
86 static int delete_all_rows();
87
88 virtual int rnd_init(bool scan);
89 virtual int rnd_next();
90 virtual int rnd_pos(const void *pos);
91 virtual void reset_position(void);
92
93protected:
94 virtual int read_row_values(TABLE *table,
95 unsigned char *buf,
96 Field **fields,
97 bool read_all);
98
99 table_esgs_by_account_by_event_name();
100
101public:
102 ~table_esgs_by_account_by_event_name()
103 {}
104
105protected:
106 void make_row(PFS_account *account, PFS_stage_class *klass);
107
108private:
109 /** Table share lock. */
110 static THR_LOCK m_table_lock;
111
112 /** Current row. */
113 row_esgs_by_account_by_event_name m_row;
114 /** True is the current row exists. */
115 bool m_row_exists;
116 /** Current position. */
117 pos_esgs_by_account_by_event_name m_pos;
118 /** Next position. */
119 pos_esgs_by_account_by_event_name m_next_pos;
120};
121
122/** @} */
123#endif
124