3 # shell script to create Bacula MySQL tables
7 if $bindir/mysql $* -f <<END-OF-DATA
10 -- Note, we use BLOB rather than TEXT because in MySQL,
11 -- BLOBs are identical to TEXT except that BLOB is case
12 -- sensitive in sorts, which is what we want, and TEXT
13 -- is case insensitive.
15 CREATE TABLE Filename (
16 FilenameId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
18 PRIMARY KEY(FilenameId),
23 PathId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
31 FileId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
32 FileIndex INTEGER UNSIGNED DEFAULT 0,
33 JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
34 PathId INTEGER UNSIGNED NOT NULL REFERENCES Path,
35 FilenameId INTEGER UNSIGNED NOT NULL REFERENCES Filename,
36 MarkId INTEGER UNSIGNED DEFAULT 0,
37 LStat TINYBLOB NOT NULL,
41 INDEX (JobId, PathId, FilenameId)
45 # Possibly add one or more of the following indexes
46 # to the above File table if your Verifies are
51 # INDEX (FilenameId, PathId)
55 CREATE TABLE MediaType (
56 MediaTypeId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
57 MediaType TINYBLOB NOT NULL,
58 ReadOnly TINYINT DEFAULT 0,
59 PRIMARY KEY(MediaTypeId)
62 CREATE TABLE Storage (
63 StorageId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
64 Name TINYBLOB NOT NULL,
65 AutoChanger TINYINT DEFAULT 0,
66 PRIMARY KEY(StorageId)
70 DeviceId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
71 Name TINYBLOB NOT NULL,
72 MediaTypeId INTEGER UNSIGNED DEFAULT 0 REFERENCES MediaType,
73 StorageId INTEGER UNSIGNED DEFAULT 0 REFERENCES Storage,
74 DevMounts INTEGER UNSIGNED DEFAULT 0,
75 DevReadBytes BIGINT UNSIGNED DEFAULT 0,
76 DevWriteBytes BIGINT UNSIGNED DEFAULT 0,
77 DevReadBytesSinceCleaning BIGINT UNSIGNED DEFAULT 0,
78 DevWriteBytesSinceCleaning BIGINT UNSIGNED DEFAULT 0,
79 DevReadTime BIGINT UNSIGNED DEFAULT 0,
80 DevWriteTime BIGINT UNSIGNED DEFAULT 0,
81 DevReadTimeSinceCleaning BIGINT UNSIGNED DEFAULT 0,
82 DevWriteTimeSinceCleaning BIGINT UNSIGNED DEFAULT 0,
83 CleaningDate DATETIME DEFAULT 0,
84 CleaningPeriod BIGINT UNSIGNED DEFAULT 0,
90 JobId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
91 Job TINYBLOB NOT NULL,
92 Name TINYBLOB NOT NULL,
93 Type BINARY(1) NOT NULL,
94 Level BINARY(1) NOT NULL,
95 ClientId INTEGER DEFAULT 0 REFERENCES Client,
96 JobStatus BINARY(1) NOT NULL,
97 SchedTime DATETIME DEFAULT 0,
98 StartTime DATETIME DEFAULT 0,
99 EndTime DATETIME DEFAULT 0,
100 RealEndTime DATETIME DEFAULT 0,
101 JobTDate BIGINT UNSIGNED DEFAULT 0,
102 VolSessionId INTEGER UNSIGNED DEFAULT 0,
103 VolSessionTime INTEGER UNSIGNED DEFAULT 0,
104 JobFiles INTEGER UNSIGNED DEFAULT 0,
105 JobBytes BIGINT UNSIGNED DEFAULT 0,
106 JobErrors INTEGER UNSIGNED DEFAULT 0,
107 JobMissingFiles INTEGER UNSIGNED DEFAULT 0,
108 PoolId INTEGER UNSIGNED DEFAULT 0 REFERENCES Pool,
109 FileSetId INTEGER UNSIGNED DEFAULT 0 REFERENCES FileSet,
110 PriorJobId INTEGER UNSIGNED DEFAULT 0 REFERENCES Job,
111 PurgedFiles TINYINT DEFAULT 0,
112 HasBase TINYINT DEFAULT 0,
118 CREATE TABLE Location (
119 LocationId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
120 Location TINYBLOB NOT NULL,
121 Cost INTEGER DEFAULT 0,
122 PRIMARY KEY(LocationId)
126 CREATE TABLE FileSet (
127 FileSetId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
128 FileSet TINYBLOB NOT NULL,
130 CreateTime DATETIME DEFAULT 0,
131 PRIMARY KEY(FileSetId)
134 CREATE TABLE JobMedia (
135 JobMediaId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
136 JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
137 MediaId INTEGER UNSIGNED NOT NULL REFERENCES Media,
138 FirstIndex INTEGER UNSIGNED DEFAULT 0,
139 LastIndex INTEGER UNSIGNED DEFAULT 0,
140 StartFile INTEGER UNSIGNED DEFAULT 0,
141 EndFile INTEGER UNSIGNED DEFAULT 0,
142 StartBlock INTEGER UNSIGNED DEFAULT 0,
143 EndBlock INTEGER UNSIGNED DEFAULT 0,
144 VolIndex INTEGER UNSIGNED DEFAULT 0,
145 Copy INTEGER UNSIGNED DEFAULT 0,
146 Stripe INTEGER UNSIGNED DEFAULT 0,
147 PRIMARY KEY(JobMediaId),
148 INDEX (JobId, MediaId)
153 MediaId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
154 VolumeName TINYBLOB NOT NULL,
155 Slot INTEGER DEFAULT 0,
156 PoolId INTEGER UNSIGNED DEFAULT 0 REFERENCES Pool,
157 MediaType TINYBLOB NOT NULL,
158 MediaTypeId INTEGER UNSIGNED DEFAULT 0 REFERENCES MediaType,
159 LabelType TINYINT DEFAULT 0,
160 FirstWritten DATETIME DEFAULT 0,
161 LastWritten DATETIME DEFAULT 0,
162 LabelDate DATETIME DEFAULT 0,
163 VolJobs INTEGER UNSIGNED DEFAULT 0,
164 VolFiles INTEGER UNSIGNED DEFAULT 0,
165 VolBlocks INTEGER UNSIGNED DEFAULT 0,
166 VolMounts INTEGER UNSIGNED DEFAULT 0,
167 VolBytes BIGINT UNSIGNED DEFAULT 0,
168 VolParts INTEGER UNSIGNED DEFAULT 0,
169 VolErrors INTEGER UNSIGNED DEFAULT 0,
170 VolWrites INTEGER UNSIGNED DEFAULT 0,
171 VolCapacityBytes BIGINT UNSIGNED DEFAULT 0,
172 VolStatus ENUM('Full', 'Archive', 'Append', 'Recycle', 'Purged',
173 'Read-Only', 'Disabled', 'Error', 'Busy', 'Used', 'Cleaning') NOT NULL,
174 Enabled TINYINT DEFAULT 1,
175 Recycle TINYINT DEFAULT 0,
176 VolRetention BIGINT UNSIGNED DEFAULT 0,
177 VolUseDuration BIGINT UNSIGNED DEFAULT 0,
178 MaxVolJobs INTEGER UNSIGNED DEFAULT 0,
179 MaxVolFiles INTEGER UNSIGNED DEFAULT 0,
180 MaxVolBytes BIGINT UNSIGNED DEFAULT 0,
181 InChanger TINYINT DEFAULT 0,
182 StorageId INTEGER UNSIGNED DEFAULT 0 REFERENCES Storage,
183 DeviceId INTEGER UNSIGNED DEFAULT 0 REFERENCES Device,
184 MediaAddressing TINYINT DEFAULT 0,
185 VolReadTime BIGINT UNSIGNED DEFAULT 0,
186 VolWriteTime BIGINT UNSIGNED DEFAULT 0,
187 EndFile INTEGER UNSIGNED DEFAULT 0,
188 EndBlock INTEGER UNSIGNED DEFAULT 0,
189 LocationId INTEGER UNSIGNED DEFAULT 0 REFERENCES Location,
190 RecycleCount INTEGER UNSIGNED DEFAULT 0,
191 InitialWrite DATETIME DEFAULT 0,
192 ScratchPoolId INTEGER UNSIGNED DEFAULT 0 REFERENCES Pool,
193 RecyclePoolId INTEGER UNSIGNED DEFAULT 0 REFERENCES Pool,
194 PRIMARY KEY(MediaId),
198 CREATE INDEX inx8 ON Media (PoolId);
203 PoolId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
204 Name TINYBLOB NOT NULL,
205 NumVols INTEGER UNSIGNED DEFAULT 0,
206 MaxVols INTEGER UNSIGNED DEFAULT 0,
207 UseOnce TINYINT DEFAULT 0,
208 UseCatalog TINYINT DEFAULT 0,
209 AcceptAnyVolume TINYINT DEFAULT 0,
210 VolRetention BIGINT UNSIGNED DEFAULT 0,
211 VolUseDuration BIGINT UNSIGNED DEFAULT 0,
212 MaxVolJobs INTEGER UNSIGNED DEFAULT 0,
213 MaxVolFiles INTEGER UNSIGNED DEFAULT 0,
214 MaxVolBytes BIGINT UNSIGNED DEFAULT 0,
215 AutoPrune TINYINT DEFAULT 0,
216 Recycle TINYINT DEFAULT 0,
217 PoolType ENUM('Backup', 'Copy', 'Cloned', 'Archive', 'Migration', 'Scratch') NOT NULL,
218 LabelType TINYINT DEFAULT 0,
219 LabelFormat TINYBLOB,
220 Enabled TINYINT DEFAULT 1,
221 ScratchPoolId INTEGER UNSIGNED DEFAULT 0 REFERENCES Pool,
222 RecyclePoolId INTEGER UNSIGNED DEFAULT 0 REFERENCES Pool,
223 NextPoolId INTEGER UNSIGNED DEFAULT 0 REFERENCES Pool,
224 MigrationHighBytes BIGINT UNSIGNED DEFAULT 0,
225 MigrationLowBytes BIGINT UNSIGNED DEFAULT 0,
226 MigrationTime BIGINT UNSIGNED DEFAULT 0,
232 CREATE TABLE Client (
233 ClientId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
234 Name TINYBLOB NOT NULL,
235 Uname TINYBLOB NOT NULL, /* full uname -a of client */
236 AutoPrune TINYINT DEFAULT 0,
237 FileRetention BIGINT UNSIGNED DEFAULT 0,
238 JobRetention BIGINT UNSIGNED DEFAULT 0,
240 PRIMARY KEY(ClientId)
243 CREATE TABLE BaseFiles (
244 BaseId INTEGER UNSIGNED AUTO_INCREMENT,
245 BaseJobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
246 JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
247 FileId INTEGER UNSIGNED NOT NULL REFERENCES File,
248 FileIndex INTEGER UNSIGNED,
252 CREATE TABLE UnsavedFiles (
253 UnsavedId INTEGER UNSIGNED AUTO_INCREMENT,
254 JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
255 PathId INTEGER UNSIGNED NOT NULL REFERENCES Path,
256 FilenameId INTEGER UNSIGNED NOT NULL REFERENCES Filename,
257 PRIMARY KEY (UnsavedId)
262 CREATE TABLE Counters (
263 Counter TINYBLOB NOT NULL,
264 MinValue INTEGER DEFAULT 0,
265 MaxValue INTEGER DEFAULT 0,
266 CurrentValue INTEGER DEFAULT 0,
267 WrapCounter TINYBLOB NOT NULL,
268 PRIMARY KEY (Counter(128))
271 CREATE TABLE CDImages (
272 MediaId INTEGER UNSIGNED NOT NULL,
273 LastBurn DATETIME NOT NULL,
274 PRIMARY KEY (MediaId)
277 CREATE TABLE Status (
278 JobStatus CHAR(1) BINARY NOT NULL,
280 PRIMARY KEY (JobStatus)
283 INSERT INTO Status (JobStatus,JobStatusLong) VALUES
284 ('C', 'Created, not yet running'),
287 ('T', 'Completed successfully'),
288 ('E', 'Terminated with errors'),
289 ('e', 'Non-fatal error'),
290 ('f', 'Fatal error'),
291 ('D', 'Verify found differences'),
292 ('A', 'Canceled by user'),
293 ('F', 'Waiting for Client'),
294 ('S', 'Waiting for Storage daemon'),
295 ('m', 'Waiting for new media'),
296 ('M', 'Waiting for media mount'),
297 ('s', 'Waiting for storage resource'),
298 ('j', 'Waiting for job resource'),
299 ('c', 'Waiting for client resource'),
300 ('d', 'Waiting on maximum jobs'),
301 ('t', 'Waiting on start time'),
302 ('p', 'Waiting on higher priority jobs');
304 CREATE TABLE Version (
305 VersionId INTEGER UNSIGNED NOT NULL
308 -- Initialize Version
309 INSERT INTO Version (VersionId) VALUES (10);
313 echo "Creation of Bacula MySQL tables succeeded."
315 echo "Creation of Bacula MySQL tables failed."