3 # shell script to create Bacula 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 *****
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 LStat TINYBLOB NOT NULL,
32 MD5 TINYBLOB NOT NULL,
41 JobId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
42 Job TINYBLOB NOT NULL,
43 Name TINYBLOB NOT NULL,
44 PurgedFiles TINYINT NOT NULL DEFAULT 0,
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 StartDay 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,
66 CREATE TABLE FileSet (
67 FileSetId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
68 FileSet TINYBLOB NOT NULL,
69 MD5 TINYBLOB NOT NULL,
70 PRIMARY KEY(FileSetId)
73 CREATE TABLE JobMedia (
74 JobMediaId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
75 JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
76 MediaId INTEGER UNSIGNED NOT NULL REFERENCES Media,
77 FirstIndex INTEGER UNSIGNED NOT NULL,
78 LastIndex INTEGER UNSIGNED NOT NULL,
79 StartFile INTEGER UNSIGNED NOT NULL,
80 EndFile INTEGER UNSIGNED NOT NULL,
81 StartBlock INTEGER UNSIGNED NOT NULL,
82 EndBlock INTEGER UNSIGNED NOT NULL,
83 PRIMARY KEY(JobMediaId),
84 INDEX (JobId, MediaId)
89 MediaId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
90 VolumeName TINYBLOB NOT NULL,
91 PoolId INTEGER UNSIGNED NOT NULL REFERENCES Pool,
92 MediaType TINYBLOB NOT NULL,
93 FirstWritten DATETIME NOT NULL,
94 LastWritten DATETIME NOT NULL,
95 LabelDate DATETIME NOT NULL,
96 VolJobs INTEGER UNSIGNED NOT NULL,
97 VolFiles INTEGER UNSIGNED NOT NULL,
98 VolBlocks INTEGER UNSIGNED NOT NULL,
99 VolMounts INTEGER UNSIGNED NOT NULL,
100 VolBytes BIGINT UNSIGNED NOT NULL,
101 VolErrors INTEGER UNSIGNED NOT NULL,
102 VolWrites INTEGER UNSIGNED NOT NULL,
103 VolMaxBytes BIGINT UNSIGNED NOT NULL,
104 VolCapacityBytes BIGINT UNSIGNED NOT NULL,
105 VolStatus ENUM('Full', 'Archive', 'Append', 'Recycle', 'Purged',
106 'Read-Only', 'Disabled', 'Error', 'Busy') NOT NULL,
107 Recycle TINYINT NOT NULL,
108 VolRetention BIGINT UNSIGNED NOT NULL,
109 PRIMARY KEY(MediaId),
114 PoolId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
115 Name TINYBLOB NOT NULL,
116 NumVols INTEGER UNSIGNED NOT NULL,
117 MaxVols INTEGER UNSIGNED NOT NULL,
118 UseOnce TINYINT NOT NULL,
119 UseCatalog TINYINT NOT NULL,
120 AcceptAnyVolume TINYINT NOT NULL,
121 VolRetention BIGINT NOT NULL,
122 AutoRecycle TINYINT NOT NULL,
123 Recycle TINYINT NOT NULL,
124 PoolType ENUM('Backup', 'Copy', 'Cloned', 'Archive', 'Migration') NOT NULL,
125 LabelFormat TINYBLOB,
131 CREATE TABLE Client (
132 ClientId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
133 Name TINYBLOB NOT NULL,
134 Uname TINYBLOB NOT NULL, /* full uname -a of client */
135 AutoPrune TINYINT NOT NULL,
136 FileRetention BIGINT NOT NULL,
137 JobRetention BIGINT NOT NULL,
139 PRIMARY KEY(ClientId)
142 CREATE TABLE Version (
143 VersionId INTEGER UNSIGNED NOT NULL
146 -- Initialize Version
147 INSERT INTO Version (VersionId) VALUES (1);
151 #CREATE TABLE FileSave (
152 # FileSaveId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
153 # FileIndex INTEGER UNSIGNED NOT NULL,
154 # JobId INTEGER UNSIGNED NOT NULL REFERENCES Job,
155 # FileId INTEGER UNSIGNED NOT NULL REFERENCES File,
156 # VLStat TINYBLOB NOT NULL,
157 # PRIMARY KEY(FileSaveId),
162 echo "Creation of Bacula tables succeeded."
164 echo "Creation of Bacula tables failed."