File: dd_resource_group.h

package info (click to toggle)
mysql-8.0 8.0.43-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 1,273,924 kB
  • sloc: cpp: 4,684,605; ansic: 412,450; pascal: 108,398; java: 83,641; perl: 30,221; cs: 27,067; sql: 26,594; sh: 24,181; python: 21,816; yacc: 17,169; php: 11,522; xml: 7,388; javascript: 7,076; makefile: 2,194; lex: 1,075; awk: 670; asm: 520; objc: 183; ruby: 97; lisp: 86
file content (91 lines) | stat: -rw-r--r-- 3,336 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/* Copyright (c) 2015, 2025, Oracle and/or its affiliates.
   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License, version 2.0,
   as published by the Free Software Foundation.

   This program is designed to work with certain software (including
   but not limited to OpenSSL) that is licensed under separate terms,
   as designated in a particular file or component or in included license
   documentation.  The authors of MySQL hereby grant you an additional
   permission to link the program and your derivative works with the
   separately licensed software that they have either included with
   the program or referenced in the documentation.

   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, version 2.0, 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 St, Fifth Floor, Boston, MA 02110-1301  USA */

#ifndef DD_RESOURCE_GROUP_INCLUDED
#define DD_RESOURCE_GROUP_INCLUDED

#include "sql/dd/string_type.h"  // dd::String_type

class THD;
namespace resourcegroups {
class Resource_group;
}
namespace dd {
namespace cache {
class Dictionary_client;
}

/**
  Check if resource group exists in the data dictionary.

  @param          dd_client            Dictionary client.
  @param          resource_group_name  Name of the resource group.
  @param  [out]   exists               Value set to true if DD object found
                                        else false.
  @retval         true                 Failure (error has been reported).
  @retval         false                Success.
*/

bool resource_group_exists(dd::cache::Dictionary_client *dd_client,
                           const String_type &resource_group_name,
                           bool *exists);

/**
  Create a DD object and persist it to DD table resourcegroup.

  @param  thd          Thread handle.
  @param  res_grp_ref  Reference to resource group.

  @retval true  Resource group creation failed.
  @retval false Resource group creation succeeded.
*/

bool create_resource_group(THD *thd,
                           const resourcegroups::Resource_group &res_grp_ref);

/**
  Update a resource group and persist it to DD table resourcegroup.

  @param thd                 Thread handle
  @param resource_grp_name   Name of the resource group.
  @param res_grp_ref         Reference to resource group.

  @retval true   Updating Resource group failed.
  @retval false  Updating Resource group succeeded.
*/

bool update_resource_group(THD *thd, const String_type &resource_grp_name,
                           const resourcegroups::Resource_group &res_grp_ref);

/**
  Drop a resource group from DD table resourcegroup.

  @param thd                 Thread handle.
  @param resource_grp_name   Name of resource group to be dropped.

  @retval true  if resource group drop failed.
  @retval false if resource group drop succeeded.
*/

bool drop_resource_group(THD *thd, const String_type resource_grp_name);
}  // namespace dd
#endif  // DD_RESOURCE_GROUP_INCLUDED