]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/cats/make_mysql_tables.in
82ed241d3ad7cde069d084508b6fe72a02b82bbd
[bacula/bacula] / bacula / src / cats / make_mysql_tables.in
1 #!/bin/sh
2 #
3 # shell script to create Bacula MySQL tables
4 #
5 bindir=@SQL_BINDIR@
6
7 if $bindir/mysql -f <<END-OF-DATA
8 USE bacula;
9 CREATE TABLE Filename (
10   FilenameId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
11   Name BLOB NOT NULL,
12   PRIMARY KEY(FilenameId),
13   INDEX (Name(30))
14   );
15
16 CREATE TABLE Path (
17    PathId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
18    Path BLOB NOT NULL,
19    PRIMARY KEY(PathId),
20    INDEX (Path(50))
21    );
22
23
24 # ****FIXME**** make FileId BIGINT someday when MySQL works *****
25 CREATE TABLE File (
26    FileId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
27    FileIndex INTEGER UNSIGNED NOT NULL,
28    JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
29    PathId INTEGER UNSIGNED NOT NULL REFERENCES Path,
30    FilenameId INTEGER NOT NULL REFERENCES Filename,
31    MarkId INTEGER UNSIGNED NOT NULL DEFAULT 0,
32    LStat TINYBLOB NOT NULL,
33    MD5 TINYBLOB NOT NULL,
34    PRIMARY KEY(FileId),
35    INDEX (JobId),
36    INDEX (PathId),
37    INDEX (FilenameId)
38    );
39
40
41 CREATE TABLE Job (
42    JobId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
43    Job TINYBLOB NOT NULL,
44    Name TINYBLOB NOT NULL,
45    PurgedFiles TINYINT NOT NULL DEFAULT 0,
46    Type BINARY(1) NOT NULL,
47    Level BINARY(1) NOT NULL,
48    ClientId INTEGER NOT NULL REFERENCES Client,
49    JobStatus BINARY(1) NOT NULL,
50    SchedTime DATETIME NOT NULL,
51    StartTime DATETIME NOT NULL,
52    EndTime DATETIME NOT NULL,
53    JobTDate BIGINT UNSIGNED NOT NULL,
54    VolSessionId INTEGER UNSIGNED NOT NULL,
55    VolSessionTime INTEGER UNSIGNED NOT NULL,
56    JobFiles INTEGER UNSIGNED NOT NULL,
57    JobBytes BIGINT UNSIGNED NOT NULL,
58    JobErrors INTEGER UNSIGNED NOT NULL,
59    JobMissingFiles INTEGER UNSIGNED NOT NULL,
60    PoolId INTEGER UNSIGNED NOT NULL REFERENCES Pool,
61    FileSetId INTEGER UNSIGNED NOT NULL REFERENCES FileSet,
62    PRIMARY KEY(JobId),
63    INDEX (Name(128))
64    );
65
66
67 CREATE TABLE FileSet (
68    FileSetId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
69    FileSet TINYBLOB NOT NULL,
70    MD5 TINYBLOB NOT NULL,
71    PRIMARY KEY(FileSetId)
72    );
73
74 CREATE TABLE JobMedia (
75    JobMediaId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
76    JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
77    MediaId INTEGER UNSIGNED NOT NULL REFERENCES Media,
78    FirstIndex INTEGER UNSIGNED NOT NULL,
79    LastIndex INTEGER UNSIGNED NOT NULL,
80    StartFile INTEGER UNSIGNED NOT NULL,
81    EndFile INTEGER UNSIGNED NOT NULL,
82    StartBlock INTEGER UNSIGNED NOT NULL,
83    EndBlock INTEGER UNSIGNED NOT NULL,
84    PRIMARY KEY(JobMediaId),
85    INDEX (JobId, MediaId)
86    );
87
88
89 CREATE TABLE Media (
90    MediaId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
91    VolumeName TINYBLOB NOT NULL,
92    Slot INTEGER NOT NULL DEFAULT 0,
93    PoolId INTEGER UNSIGNED NOT NULL REFERENCES Pool,
94    MediaType TINYBLOB NOT NULL,
95    FirstWritten DATETIME NOT NULL,
96    LastWritten DATETIME NOT NULL,
97    LabelDate DATETIME NOT NULL,
98    VolJobs INTEGER UNSIGNED NOT NULL,
99    VolFiles INTEGER UNSIGNED NOT NULL,
100    VolBlocks INTEGER UNSIGNED NOT NULL,
101    VolMounts INTEGER UNSIGNED NOT NULL,
102    VolBytes BIGINT UNSIGNED NOT NULL,
103    VolErrors INTEGER UNSIGNED NOT NULL,
104    VolWrites INTEGER UNSIGNED NOT NULL,
105    MaxVolBytes BIGINT UNSIGNED NOT NULL,
106    VolCapacityBytes BIGINT UNSIGNED NOT NULL,
107    VolStatus ENUM('Full', 'Archive', 'Append', 'Recycle', 'Purged',
108     'Read-Only', 'Disabled', 'Error', 'Busy', 'Used') NOT NULL,
109    Recycle TINYINT NOT NULL,
110    VolRetention BIGINT UNSIGNED NOT NULL,
111    VolUseDuration BIGINT UNSIGNED NOT NULL,
112    MaxVolJobs INTEGER UNSIGNED NOT NULL,
113    MaxVolFiles INTEGER UNSIGNED NOT NULL,
114    PRIMARY KEY(MediaId),
115    INDEX (PoolId)
116    );
117
118 CREATE TABLE Pool (
119    PoolId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
120    Name TINYBLOB NOT NULL,
121    NumVols INTEGER UNSIGNED NOT NULL,
122    MaxVols INTEGER UNSIGNED NOT NULL,
123    UseOnce TINYINT NOT NULL,
124    UseCatalog TINYINT NOT NULL,
125    AcceptAnyVolume TINYINT DEFAULT 0,
126    VolRetention BIGINT UNSIGNED NOT NULL,
127    VolUseDuration BIGINT UNSIGNED NOT NULL,
128    MaxVolJobs INTEGER UNSIGNED NOT NULL,
129    MaxVolFiles INTEGER UNSIGNED NOT NULL,
130    MaxVolBytes BIGINT UNSIGNED NOT NULL,
131    AutoPrune TINYINT DEFAULT 0,
132    Recycle TINYINT DEFAULT 0,
133    PoolType ENUM('Backup', 'Copy', 'Cloned', 'Archive', 'Migration') NOT NULL,
134    LabelFormat TINYBLOB,
135    UNIQUE (Name(128)),
136    PRIMARY KEY (PoolId)
137    );
138
139
140 CREATE TABLE Client (
141    ClientId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
142    Name TINYBLOB NOT NULL,
143    Uname TINYBLOB NOT NULL,       /* full uname -a of client */
144    AutoPrune TINYINT DEFAULT 0,
145    FileRetention BIGINT UNSIGNED NOT NULL,
146    JobRetention  BIGINT UNSIGNED NOT NULL,
147    UNIQUE (Name(128)),
148    PRIMARY KEY(ClientId)
149    );
150
151 CREATE TABLE Version (
152    VersionId INTEGER UNSIGNED NOT NULL 
153    );
154
155 -- Initialize Version            
156 INSERT INTO Version (VersionId) VALUES (4);
157
158 CREATE TABLE Counters (
159    Counter TINYBLOB NOT NULL,
160    PoolId INTEGER UNSIGNED NOT NULL REFERENCES Pool,
161    MinValue INTEGER,
162    MaxValue INTEGER,
163    CurrentValue INTEGER,
164    WrapCounter TINYBLOB NOT NULL
165    );
166
167 ## Experimental
168 #CREATE TABLE FileSave (
169 #   FileSaveId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
170 #   FileIndex INTEGER UNSIGNED NOT NULL,
171 #   JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
172 #   FileId INTEGER UNSIGNED NOT NULL REFERENCES File,
173 #   VLStat TINYBLOB NOT NULL,
174 #   PRIMARY KEY(FileSaveId),
175 #   );
176
177 # Experimental stuff below. Not used.
178 # Invariant part of File
179 #CREATE TABLE BaseFile (
180 #   FileId INTEGER UNSIGNED AUTOINCREMENT,
181 #   PathId INTEGER UNSIGNED REFERENCES Path NOT NULL,
182 #   FilenameId INTEGER REFERENCES Filename NOT NULL,
183 #   LStat VARCHAR(255) NOT NULL,
184 #   MD5 VARCHAR(25) NOT NULL,
185 #   PRIMARY KEY(FileId) 
186 #   );
187
188 # Variable part of File
189 #CREATE TABLE FileSave (
190 #   FileId INTEGER UNSIGNED REFERENCES BaseFile NOT NULL,
191 #   FileIndex INTEGER UNSIGNED NOT NULL,
192 #   JobId INTEGER UNSIGNED REFERENCES Job NOT NULL,
193 #   PRIMARY KEY(FileId) 
194 #   );
195
196
197 END-OF-DATA
198 then
199    echo "Creation of Bacula tables succeeded."
200 else
201    echo "Creation of Bacula tables failed."
202 fi
203 exit 0