]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/cats/make_mysql_tables.in
Retention period updates
[bacula/bacula] / bacula / src / cats / make_mysql_tables.in
1 #!/bin/sh
2 #
3 # shell script to create Bacula 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 *****
25 CREATE TABLE File (
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,
33    PRIMARY KEY(FileId),
34    INDEX (JobId),
35    INDEX (PathId),
36    INDEX (FilenameId)
37    );
38
39
40 CREATE TABLE Job (
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,
61    PRIMARY KEY(JobId),
62    INDEX (Name(128))
63    );
64
65
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)
71    );
72
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)
85    );
86
87
88 CREATE TABLE Media (
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),
110    INDEX (PoolId)
111    );
112
113 CREATE TABLE Pool (
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,
126    UNIQUE (Name(128)),
127    PRIMARY KEY (PoolId)
128    );
129
130
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,
138    UNIQUE (Name(128)),
139    PRIMARY KEY(ClientId)
140    );
141
142 CREATE TABLE Version (
143    VersionId INTEGER UNSIGNED NOT NULL 
144    );
145
146 -- Initialize Version            
147 INSERT INTO Version (VersionId) VALUES (1);
148
149
150 ## Experimental
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),
158 #   );
159
160 END-OF-DATA
161 then
162    echo "Creation of Bacula tables succeeded."
163 else
164    echo "Creation of Bacula tables failed."
165 fi
166 exit 0