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 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,
54 VolSessionTime INTEGER UNSIGNED NOT NULL,
55 JobFiles INTEGER UNSIGNED NOT NULL,
56 JobBytes BIGINT UNSIGNED NOT NULL,
57 JobErrors INTEGER UNSIGNED NOT NULL,
58 JobMissingFiles INTEGER UNSIGNED NOT NULL,
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,
81 LastIndex INTEGER UNSIGNED NOT NULL,
82 StartFile INTEGER UNSIGNED NOT NULL,
83 EndFile INTEGER UNSIGNED NOT NULL,
84 StartBlock INTEGER UNSIGNED NOT NULL,
85 EndBlock INTEGER UNSIGNED NOT NULL,
86 VolIndex INTEGER UNSIGNED NOT NULL,
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,
102 VolFiles INTEGER UNSIGNED NOT NULL,
103 VolBlocks INTEGER UNSIGNED NOT NULL,
104 VolMounts INTEGER UNSIGNED NOT NULL,
105 VolBytes BIGINT UNSIGNED NOT NULL,
106 VolErrors INTEGER UNSIGNED NOT NULL,
107 VolWrites INTEGER UNSIGNED NOT NULL,
108 MaxVolBytes BIGINT UNSIGNED NOT NULL,
109 VolCapacityBytes BIGINT UNSIGNED NOT NULL,
110 VolStatus ENUM('Full', 'Archive', 'Append', 'Recycle', 'Purged',
111 'Read-Only', 'Disabled', 'Error', 'Busy', 'Used', 'Cleaning') NOT NULL,
112 Recycle TINYINT NOT NULL,
113 VolRetention BIGINT UNSIGNED NOT NULL,
114 VolUseDuration BIGINT UNSIGNED NOT NULL,
115 MaxVolJobs INTEGER UNSIGNED NOT NULL,
116 MaxVolFiles INTEGER UNSIGNED NOT NULL,
117 PRIMARY KEY(MediaId),
122 PoolId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
123 Name TINYBLOB NOT NULL,
124 NumVols INTEGER UNSIGNED NOT NULL,
125 MaxVols INTEGER UNSIGNED NOT NULL,
126 UseOnce TINYINT NOT NULL,
127 UseCatalog TINYINT NOT NULL,
128 AcceptAnyVolume TINYINT DEFAULT 0,
129 VolRetention BIGINT UNSIGNED NOT NULL,
130 VolUseDuration BIGINT UNSIGNED NOT NULL,
131 MaxVolJobs INTEGER UNSIGNED NOT NULL,
132 MaxVolFiles INTEGER UNSIGNED NOT NULL,
133 MaxVolBytes BIGINT UNSIGNED NOT NULL,
134 AutoPrune TINYINT DEFAULT 0,
135 Recycle TINYINT DEFAULT 0,
136 PoolType ENUM('Backup', 'Copy', 'Cloned', 'Archive', 'Migration') NOT NULL,
137 LabelFormat TINYBLOB,
143 CREATE TABLE Client (
144 ClientId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
145 Name TINYBLOB NOT NULL,
146 Uname TINYBLOB NOT NULL, /* full uname -a of client */
147 AutoPrune TINYINT DEFAULT 0,
148 FileRetention BIGINT UNSIGNED NOT NULL,
149 JobRetention BIGINT UNSIGNED NOT NULL,
151 PRIMARY KEY(ClientId)
154 CREATE TABLE BaseFiles (
155 BaseId INTEGER UNSIGNED AUTO_INCREMENT,
156 JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
157 FileId INTEGER UNSIGNED NOT NULL REFERENCES File,
158 FileIndex INTEGER UNSIGNED,
162 CREATE TABLE UnsavedFiles (
163 UnsavedId INTEGER UNSIGNED AUTO_INCREMENT,
164 JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
165 PathId INTEGER UNSIGNED NOT NULL REFERENCES Path,
166 FilenameId INTEGER UNSIGNED NOT NULL REFERENCES Filename,
167 PRIMARY KEY (UnsavedId)
171 CREATE TABLE Version (
172 VersionId INTEGER UNSIGNED NOT NULL
175 -- Initialize Version
176 INSERT INTO Version (VersionId) VALUES (6);
178 CREATE TABLE Counters (
179 Counter TINYBLOB NOT NULL,
180 PoolId INTEGER UNSIGNED NOT NULL REFERENCES Pool,
183 CurrentValue INTEGER,
184 WrapCounter TINYBLOB NOT NULL
190 echo "Creation of Bacula MySQL tables succeeded."
192 echo "Creation of Bacula MySQL tables failed."