3 # shell script to create Bacula MySQL tables
7 if $bindir/mysql -f <<END-OF-DATA
9 CREATE TABLE Filename (
10 FilenameId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
12 PRIMARY KEY(FilenameId),
17 PathId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
24 # ****FIXME**** make FileId BIGINT someday when MySQL works *****
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,
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,
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)
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)
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),
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,
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,
148 PRIMARY KEY(ClientId)
151 CREATE TABLE Version (
152 VersionId INTEGER UNSIGNED NOT NULL
155 -- Initialize Version
156 INSERT INTO Version (VersionId) VALUES (5);
158 CREATE TABLE Counters (
159 Counter TINYBLOB NOT NULL,
160 PoolId INTEGER UNSIGNED NOT NULL REFERENCES Pool,
163 CurrentValue INTEGER,
164 WrapCounter TINYBLOB NOT NULL
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),
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)
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)
199 echo "Creation of Bacula tables succeeded."
201 echo "Creation of Bacula tables failed."