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 DEFAULT 0,
28 JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
29 PathId INTEGER UNSIGNED NOT NULL REFERENCES Path,
30 FilenameId INTEGER UNSIGNED 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 Type BINARY(1) NOT NULL,
46 Level BINARY(1) NOT NULL,
47 ClientId INTEGER NOT NULL REFERENCES Client,
48 JobStatus BINARY(1) NOT NULL,
49 SchedTime DATETIME NOT NULL,
50 StartTime DATETIME NOT NULL,
51 EndTime DATETIME NOT NULL,
52 JobTDate BIGINT UNSIGNED NOT NULL,
53 VolSessionId INTEGER UNSIGNED NOT NULL DEFAULT 0,
54 VolSessionTime INTEGER UNSIGNED NOT NULL DEFAULT 0,
55 JobFiles INTEGER UNSIGNED NOT NULL DEFAULT 0,
56 JobBytes BIGINT UNSIGNED NOT NULL,
57 JobErrors INTEGER UNSIGNED NOT NULL DEFAULT 0,
58 JobMissingFiles INTEGER UNSIGNED NOT NULL DEFAULT 0,
59 PoolId INTEGER UNSIGNED NOT NULL REFERENCES Pool,
60 FileSetId INTEGER UNSIGNED NOT NULL REFERENCES FileSet,
61 PurgedFiles TINYINT NOT NULL DEFAULT 0,
62 HasBase TINYINT NOT NULL DEFAULT 0,
68 CREATE TABLE FileSet (
69 FileSetId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
70 FileSet TINYBLOB NOT NULL,
71 MD5 TINYBLOB NOT NULL,
72 CreateTime DATETIME NOT NULL,
73 PRIMARY KEY(FileSetId)
76 CREATE TABLE JobMedia (
77 JobMediaId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
78 JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
79 MediaId INTEGER UNSIGNED NOT NULL REFERENCES Media,
80 FirstIndex INTEGER UNSIGNED NOT NULL DEFAULT 0,
81 LastIndex INTEGER UNSIGNED NOT NULL DEFAULT 0,
82 StartFile INTEGER UNSIGNED NOT NULL DEFAULT 0,
83 EndFile INTEGER UNSIGNED NOT NULL DEFAULT 0,
84 StartBlock INTEGER UNSIGNED NOT NULL DEFAULT 0,
85 EndBlock INTEGER UNSIGNED NOT NULL DEFAULT 0,
86 VolIndex INTEGER UNSIGNED NOT NULL DEFAULT 0,
87 PRIMARY KEY(JobMediaId),
88 INDEX (JobId, MediaId)
93 MediaId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
94 VolumeName TINYBLOB NOT NULL,
95 Slot INTEGER NOT NULL DEFAULT 0,
96 PoolId INTEGER UNSIGNED NOT NULL REFERENCES Pool,
97 MediaType TINYBLOB NOT NULL,
98 FirstWritten DATETIME NOT NULL,
99 LastWritten DATETIME NOT NULL,
100 LabelDate DATETIME NOT NULL,
101 VolJobs INTEGER UNSIGNED NOT NULL DEFAULT 0,
102 VolFiles INTEGER UNSIGNED NOT NULL DEFAULT 0,
103 VolBlocks INTEGER UNSIGNED NOT NULL DEFAULT 0,
104 VolMounts INTEGER UNSIGNED NOT NULL DEFAULT 0,
105 VolBytes BIGINT UNSIGNED NOT NULL DEFAULT 0,
106 VolErrors INTEGER UNSIGNED NOT NULL DEFAULT 0,
107 VolWrites INTEGER UNSIGNED NOT NULL DEFAULT 0,
108 VolCapacityBytes BIGINT UNSIGNED NOT NULL,
109 VolStatus ENUM('Full', 'Archive', 'Append', 'Recycle', 'Purged',
110 'Read-Only', 'Disabled', 'Error', 'Busy', 'Used', 'Cleaning') NOT NULL,
111 Recycle TINYINT NOT NULL DEFAULT 0,
112 VolRetention BIGINT UNSIGNED NOT NULL DEFAULT 0,
113 VolUseDuration BIGINT UNSIGNED NOT NULL DEFAULT 0,
114 MaxVolJobs INTEGER UNSIGNED NOT NULL DEFAULT 0,
115 MaxVolFiles INTEGER UNSIGNED NOT NULL DEFAULT 0,
116 MaxVolBytes BIGINT UNSIGNED NOT NULL DEFAULT 0,
117 InChanger TINYINT NOT NULL DEFAULT 0,
118 MediaAddressing TINYINT NOT NULL DEFAULT 0,
119 VolReadTime BIGINT UNSIGNED NOT NULL DEFAULT 0,
120 VolWriteTime BIGINT UNSIGNED NOT NULL DEFAULT 0,
121 PRIMARY KEY(MediaId),
126 PoolId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
127 Name TINYBLOB NOT NULL,
128 NumVols INTEGER UNSIGNED NOT NULL DEFAULT 0,
129 MaxVols INTEGER UNSIGNED NOT NULL DEFAULT 0,
130 UseOnce TINYINT NOT NULL,
131 UseCatalog TINYINT NOT NULL,
132 AcceptAnyVolume TINYINT DEFAULT 0,
133 VolRetention BIGINT UNSIGNED NOT NULL,
134 VolUseDuration BIGINT UNSIGNED NOT NULL,
135 MaxVolJobs INTEGER UNSIGNED NOT NULL DEFAULT 0,
136 MaxVolFiles INTEGER UNSIGNED NOT NULL DEFAULT 0,
137 MaxVolBytes BIGINT UNSIGNED NOT NULL,
138 AutoPrune TINYINT DEFAULT 0,
139 Recycle TINYINT DEFAULT 0,
140 PoolType ENUM('Backup', 'Copy', 'Cloned', 'Archive', 'Migration', 'Scratch') NOT NULL,
141 LabelFormat TINYBLOB,
142 Enabled TINYINT DEFAULT 1,
143 ScratchPoolId INTEGER UNSIGNED DEFAULT 0 REFERENCES Pool,
144 RecyclePoolId INTEGER UNSIGNED DEFAULT 0 REFERENCES Pool,
150 CREATE TABLE Client (
151 ClientId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
152 Name TINYBLOB NOT NULL,
153 Uname TINYBLOB NOT NULL, /* full uname -a of client */
154 AutoPrune TINYINT DEFAULT 0,
155 FileRetention BIGINT UNSIGNED NOT NULL,
156 JobRetention BIGINT UNSIGNED NOT NULL,
158 PRIMARY KEY(ClientId)
161 CREATE TABLE BaseFiles (
162 BaseId INTEGER UNSIGNED AUTO_INCREMENT,
163 BaseJobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
164 JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
165 FileId INTEGER UNSIGNED NOT NULL REFERENCES File,
166 FileIndex INTEGER UNSIGNED,
170 CREATE TABLE UnsavedFiles (
171 UnsavedId INTEGER UNSIGNED AUTO_INCREMENT,
172 JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
173 PathId INTEGER UNSIGNED NOT NULL REFERENCES Path,
174 FilenameId INTEGER UNSIGNED NOT NULL REFERENCES Filename,
175 PRIMARY KEY (UnsavedId)
179 CREATE TABLE Version (
180 VersionId INTEGER UNSIGNED NOT NULL
183 -- Initialize Version
184 INSERT INTO Version (VersionId) VALUES (7);
186 CREATE TABLE Counters (
187 Counter TINYBLOB NOT NULL,
190 CurrentValue INTEGER,
191 WrapCounter TINYBLOB NOT NULL,
192 PRIMARY KEY (Counter(128))
198 echo "Creation of Bacula MySQL tables succeeded."
200 echo "Creation of Bacula MySQL tables failed."