]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/cats/make_mysql_tables.in
SQL updates + Vol read/write times
[bacula/bacula] / bacula / src / cats / make_mysql_tables.in
1 #!/bin/sh
2 #
3 # shell script to create Bacula MySQL tables
4 #
5 bindir=@SQL_BINDIR@
6
7 if $bindir/mysql $* -f <<END-OF-DATA
8 USE bacula;
9 CREATE TABLE Filename (
10   FilenameId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
11   Name BLOB NOT NULL,
12   PRIMARY KEY(FilenameId),
13   INDEX (Name(30))
14   );
15
16 CREATE TABLE Path (
17    PathId INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
18    Path BLOB NOT NULL,
19    PRIMARY KEY(PathId),
20    INDEX (Path(50))
21    );
22
23
24 # ****FIXME**** make FileId BIGINT someday when MySQL works *****
25 CREATE TABLE File (
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,
34    PRIMARY KEY(FileId),
35    INDEX (JobId),
36    INDEX (PathId),
37    INDEX (FilenameId)
38    );
39
40
41 CREATE TABLE Job (
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,
63    PRIMARY KEY(JobId),
64    INDEX (Name(128))
65    );
66
67
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)
74    );
75
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)
89    );
90
91
92 CREATE TABLE Media (
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 DEAULT 0,
120    VolWriteTime BIGINT UNSIGNED NOT NULL DEFAULT 0,
121    PRIMARY KEY(MediaId),
122    INDEX (PoolId)
123    );
124
125 CREATE TABLE Pool (
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,
145    UNIQUE (Name(128)),
146    PRIMARY KEY (PoolId)
147    );
148
149
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,
157    UNIQUE (Name(128)),
158    PRIMARY KEY(ClientId)
159    );
160
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,
167    PRIMARY KEY(BaseId)
168    );
169
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)
176    );
177
178
179 CREATE TABLE Version (
180    VersionId INTEGER UNSIGNED NOT NULL 
181    );
182
183 -- Initialize Version            
184 INSERT INTO Version (VersionId) VALUES (7);
185
186 CREATE TABLE Counters (
187    Counter TINYBLOB NOT NULL,
188    MinValue INTEGER,
189    MaxValue INTEGER,
190    CurrentValue INTEGER,
191    WrapCounter TINYBLOB NOT NULL,
192    PRIMARY KEY (Counter(128))
193    );
194
195
196 END-OF-DATA
197 then
198    echo "Creation of Bacula MySQL tables succeeded."
199 else
200    echo "Creation of Bacula MySQL tables failed."
201 fi
202 exit 0