VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/testmanager/db/tmdb-r10-testresultvalues-2.pgsql@ 100762

Last change on this file since 100762 was 98103, checked in by vboxsync, 2 years ago

Copyright year updates by scm.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.2 KB
Line 
1-- $Id: tmdb-r10-testresultvalues-2.pgsql 98103 2023-01-17 14:15:46Z vboxsync $
2--- @file
3-- VBox Test Manager Database - Adds an idTestSet to TestResultValues.
4--
5
6--
7-- Copyright (C) 2013-2023 Oracle and/or its affiliates.
8--
9-- This file is part of VirtualBox base platform packages, as
10-- available from https://www.virtualbox.org.
11--
12-- This program is free software; you can redistribute it and/or
13-- modify it under the terms of the GNU General Public License
14-- as published by the Free Software Foundation, in version 3 of the
15-- License.
16--
17-- This program is distributed in the hope that it will be useful, but
18-- WITHOUT ANY WARRANTY; without even the implied warranty of
19-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20-- General Public License for more details.
21--
22-- You should have received a copy of the GNU General Public License
23-- along with this program; if not, see <https://www.gnu.org/licenses>.
24--
25-- The contents of this file may alternatively be used under the terms
26-- of the Common Development and Distribution License Version 1.0
27-- (CDDL), a copy of it is provided in the "COPYING.CDDL" file included
28-- in the VirtualBox distribution, in which case the provisions of the
29-- CDDL are applicable instead of those of the GPL.
30--
31-- You may elect to license modified versions of this file under the
32-- terms and conditions of either the GPL or the CDDL or both.
33--
34-- SPDX-License-Identifier: GPL-3.0-only OR CDDL-1.0
35--
36
37--
38-- Cleanup after failed runs.
39--
40DROP TABLE NewTestResultValues;
41
42--
43-- Drop all indexes (might already be dropped).
44--
45DROP INDEX TestResultValuesIdx;
46DROP INDEX TestResultValuesNameIdx;
47
48-- Die on error from now on.
49\set ON_ERROR_STOP 1
50\set AUTOCOMMIT 0
51
52\d+ TestResultValues;
53
54--
55-- Create the new version of the table and filling with the content of the old.
56--
57CREATE TABLE NewTestResultValues (
58 --- The ID of this value.
59 idTestResultValue INTEGER DEFAULT NEXTVAL('TestResultValueIdSeq'), -- PRIMARY KEY
60 --- The test result it was reported within.
61 idTestResult INTEGER NOT NULL, -- REFERENCES TestResults(idTestResult) NOT NULL,
62 --- The test result it was reported within.
63 idTestSet INTEGER NOT NULL, -- REFERENCES TestSets(idTestSet) NOT NULL,
64 --- Creation time stamp.
65 tsCreated TIMESTAMP WITH TIME ZONE DEFAULT current_timestamp NOT NULL,
66 --- The name.
67 idStrName INTEGER NOT NULL, -- REFERENCES TestResultStrTab(idStr) NOT NULL,
68 --- The value.
69 lValue bigint NOT NULL,
70 --- The unit.
71 -- @todo This is currently not defined properly. Will fix/correlate this
72 -- with the other places we use unit (IPRT/testdriver/VMMDev).
73 iUnit smallint NOT NULL --CHECK (iUnit >= 0 AND iUnit < 1024)
74);
75COMMIT;
76\d+ NewTestResultValues
77
78-- Note! Using left out join here to speed up things (no hashing).
79SELECT COUNT(*) FROM TestResultValues a LEFT OUTER JOIN TestResults b ON (a.idTestResult = b.idTestResult);
80SELECT COUNT(*) FROM TestResultValues;
81
82INSERT INTO NewTestResultValues (idTestResultValue, idTestResult, idTestSet, tsCreated, idStrName, lValue, iUnit)
83 SELECT a.idTestResultValue, a.idTestResult, b.idTestSet, a.tsCreated, a.idStrName, a.lValue, a.iUnit
84 FROM TestResultValues a LEFT OUTER JOIN TestResults b ON (a.idTestResult = b.idTestResult);
85COMMIT;
86SELECT COUNT(*) FROM NewTestResultValues;
87
88-- Switch the tables.
89ALTER TABLE TestResultValues RENAME TO OldTestResultValues;
90ALTER TABLE NewTestResultValues RENAME TO TestResultValues;
91COMMIT;
92
93-- Index the table.
94CREATE INDEX TestResultValuesIdx ON TestResultValues(idTestResult);
95CREATE INDEX TestResultValuesNameIdx ON TestResultValues(idStrName, tsCreated);
96COMMIT;
97
98-- Drop the old table.
99DROP TABLE OldTestResultValues;
100COMMIT;
101
102-- Add the constraints constraint.
103ALTER TABLE TestResultValues ADD CONSTRAINT TestResultValues_iUnit_Check CHECK (iUnit >= 0 AND iUnit < 1024);
104ALTER TABLE TestResultValues ADD PRIMARY KEY (idTestResultValue);
105ALTER TABLE TestResultValues ADD FOREIGN KEY (idStrName) REFERENCES TestResultstrtab(idStr);
106ALTER TABLE TestResultValues ADD FOREIGN KEY (idTestResult) REFERENCES TestResults(idTestResult);
107ALTER TABLE TestResultValues ADD FOREIGN KEY (idTestSet) REFERENCES TestSets(idTestSet);
108COMMIT;
109
110\d+ TestResultValues;
111
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette