aboutsummaryrefslogtreecommitdiffstats
path: root/packages/policy-xacmlpdp-tarball/src/main/resources/mysql/sql/createguardtable.sql
blob: 34851a6fc5cd70497bf7b4a5797b2620a67d8fac (plain)
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
-- ============LICENSE_START=======================================================
-- Copyright (C) 2019-2022 AT&T Intellectual Property. All rights reserved.
-- ================================================================================
-- Licensed under the Apache License, Version 2.0 (the "License");
-- you may not use this file except in compliance with the License.
-- You may obtain a copy of the License at
--
--      http://www.apache.org/licenses/LICENSE-2.0
--
-- Unless required by applicable law or agreed to in writing, software
-- distributed under the License is distributed on an "AS IS" BASIS,
-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-- See the License for the specific language governing permissions and
-- limitations under the License.
-- ============LICENSE_END=========================================================

USE operationshistory;

CREATE TABLE IF NOT EXISTS operationshistory (
    id INT(11) NOT NULL AUTO_INCREMENT,
    closedLoopName VARCHAR(255) NOT NULL,
    requestId VARCHAR(50),
    actor VARCHAR(50) NOT NULL,
    operation VARCHAR(50) NOT NULL,
    target VARCHAR(50) NOT NULL,
    starttime timestamp NOT NULL,
    outcome VARCHAR(50) NOT NULL,
    message VARCHAR(255),
    subrequestId VARCHAR(50),
    endtime timestamp NULL DEFAULT current_timestamp,
    PRIMARY KEY (id)
);

DROP PROCEDURE IF EXISTS create_clreqid_index;

\d $$
CREATE PROCEDURE create_clreqid_index()
BEGIN
    DECLARE index_count INT DEFAULT 1;

    SELECT count(index_name) INTO index_count FROM information_schema.statistics
    WHERE table_schema=DATABASE() AND table_name='operationshistory' AND index_name='operationshistory_clreqid_index';

    IF index_count = 0 THEN
        CREATE INDEX operationshistory_clreqid_index ON operationshistory(requestId, closedLoopName);
    END IF;
END
$$

\d ;

CALL create_clreqid_index();

DROP PROCEDURE IF EXISTS create_target_index;

\d $$
CREATE PROCEDURE create_target_index()
BEGIN
    DECLARE index_count INT DEFAULT 1;

    SELECT count(index_name) INTO index_count FROM information_schema.statistics
    WHERE table_schema=DATABASE() AND table_name='operationshistory' AND index_name='operationshistory_target_index';

    IF index_count = 0 THEN
        CREATE INDEX operationshistory_target_index ON operationshistory(target, operation, actor, endtime);
    END IF;
END
$$

CALL create_target_index();
\d ;