]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/cats/make_sqlite_tables.in
Minor updates + doc -- see kes21Nov02
[bacula/bacula] / bacula / src / cats / make_sqlite_tables.in
1 #!/bin/sh
2 #
3 # shell script to create Bacula SQLite tables
4
5 bindir=@SQL_BINDIR@
6 cd @working_dir@
7
8 $bindir/sqlite bacula.db <<END-OF-DATA
9 CREATE TABLE Filename (
10   FilenameId INTEGER UNSIGNED AUTOINCREMENT,
11   Name TEXT DEFAULT "",
12   PRIMARY KEY(FilenameId) 
13   );
14
15 CREATE INDEX inx1 ON Filename (Name);
16
17 CREATE TABLE Path (
18    PathId INTEGER UNSIGNED AUTOINCREMENT,
19    Path TEXT DEFAULT "",
20    PRIMARY KEY(PathId) 
21    );
22
23 CREATE INDEX inx2 ON Path (Path);
24
25
26 CREATE TABLE File (
27    FileId INTEGER UNSIGNED AUTOINCREMENT,
28    FileIndex INTEGER UNSIGNED NOT NULL,
29    JobId INTEGER UNSIGNED REFERENCES Job NOT NULL,
30    PathId INTEGER UNSIGNED REFERENCES Path NOT NULL,
31    FilenameId INTEGER REFERENCES Filename NOT NULL,
32    MarkId INTEGER UNSIGNED DEFAULT 0,
33    LStat VARCHAR(255) NOT NULL,
34    MD5 VARCHAR(25) NOT NULL,
35    PRIMARY KEY(FileId) 
36    );
37
38 CREATE INDEX inx3 ON File (JobId);
39 CREATE INDEX inx4 ON File (PathId);
40 CREATE INDEX inx5 ON File (FileNameId);
41
42 CREATE TABLE Job (
43    JobId INTEGER UNSIGNED NOT NULL,
44    Job VARCHAR(128) NOT NULL,
45    Name VARCHAR(128) NOT NULL,
46    PurgedFiles TINYINT DEFAULT 0,
47    Type CHAR NOT NULL,
48    Level CHAR NOT NULL,
49    ClientId INTEGER REFERENCES Client DEFAULT 0,
50    JobStatus CHAR NOT NULL,
51    SchedTime DATETIME NOT NULL,
52    StartTime DATETIME DEFAULT 0,
53    EndTime DATETIME DEFAULT 0,
54    JobTDate BIGINT UNSIGNED DEFAULT 0,
55    VolSessionId INTEGER UNSIGNED DEFAULT 0,
56    VolSessionTime INTEGER UNSIGNED DEFAULT 0,
57    JobFiles INTEGER UNSIGNED DEFAULT 0,
58    JobBytes BIGINT UNSIGNED DEFAULT 0,
59    JobErrors INTEGER UNSIGNED DEFAULT 0,
60    JobMissingFiles INTEGER UNSIGNED DEFAULT 0,
61    PoolId INTEGER UNSIGNED REFERENCES Pool DEFAULT 0,
62    FileSetId INTEGER UNSIGNED REFERENCES FileSet DEFAULT 0,
63    PRIMARY KEY(JobId) 
64    );
65
66 CREATE INDEX inx6 ON Job (Name);
67
68 CREATE TABLE FileSet (
69    FileSetId INTEGER UNSIGNED AUTOINCREMENT,
70    FileSet VARCHAR(128) NOT NULL,
71    MD5 VARCHAR(25) NOT NULL,
72    PRIMARY KEY(FileSetId)
73    );
74
75 CREATE TABLE JobMedia (
76    JobMediaId INTEGER UNSIGNED AUTOINCREMENT,
77    JobId INTEGER UNSIGNED REFERENCES Job NOT NULL,
78    MediaId INTEGER UNSIGNED REFERENCES Media NOT NULL,
79    FirstIndex INTEGER UNSIGNED NOT NULL,
80    LastIndex INTEGER UNSIGNED NOT NULL,
81    StartFile INTEGER UNSIGNED DEFAULT 0,
82    EndFile INTEGER UNSIGNED DEFAULT 0,
83    StartBlock INTEGER UNSIGNED DEFAULT 0,
84    EndBlock INTEGER UNSIGNED DEFAULT 0,
85    PRIMARY KEY(JobMediaId) 
86    );
87
88 CREATE INDEX inx7 ON JobMedia (JobId, MediaId);
89
90
91 CREATE TABLE Media (
92    MediaId INTEGER UNSIGNED AUTOINCREMENT,
93    VolumeName VARCHAR(128) NOT NULL,
94    Slot INTEGER DEFAULT 0,
95    PoolId INTEGER UNSIGNED REFERENCES Pool NOT NULL,
96    MediaType VARCHAR(128) NOT NULL,
97    FirstWritten DATETIME DEFAULT 0,
98    LastWritten DATETIME DEFAULT 0,
99    LabelDate DATETIME DEFAULT 0,
100    VolJobs INTEGER UNSIGNED DEFAULT 0,
101    VolFiles INTEGER UNSIGNED DEFAULT 0,
102    VolBlocks INTEGER UNSIGNED DEFAULT 0,
103    VolMounts INTEGER UNSIGNED DEFAULT 0,
104    VolBytes BIGINT UNSIGNED DEFAULT 0,
105    VolErrors INTEGER UNSIGNED DEFAULT 0,
106    VolWrites INTEGER UNSIGNED DEFAULT 0,
107    MaxVolBytes BIGINT UNSIGNED DEFAULT 0,
108    VolCapacityBytes BIGINT UNSIGNED DEFAULT 0,
109    VolStatus VARCHAR(20) NOT NULL,
110    Recycle TINYINT DEFAULT 0,
111    VolRetention BIGINT UNSIGNED DEFAULT 0,
112    VolUseDuration BIGINT UNSIGNED DEFAULT 0,
113    MaxVolJobs INTEGER UNSIGNED DEFAULT 0,
114    MaxVolFiles INTEGER UNSIGNED DEFAULT 0,
115    MaxVolBytes BIGINT UNSIGNED DEFAULT 0,
116    PRIMARY KEY(MediaId)
117    );
118
119 CREATE INDEX inx8 ON Media (PoolId);
120
121 CREATE TABLE Pool (
122    PoolId INTEGER UNSIGNED AUTOINCREMENT,
123    Name VARCHAR(128) NOT NULL,
124    NumVols INTEGER UNSIGNED DEFAULT 0,
125    MaxVols INTEGER UNSIGNED DEFAULT 0,
126    UseOnce TINYINT DEFAULT 0,
127    UseCatalog TINYINT DEFAULT 1,
128    AcceptAnyVolume TINYINT DEFAULT 0,
129    VolRetention BIGINT UNSIGNED DEFAULT 0,
130    VolUseDuration BIGINT UNSIGNED DEFAULT 0,
131    MaxVolJobs INTEGER UNSIGNED DEFAULT 0,
132    MaxVolFiles INTEGER UNSIGNED DEFAULT 0,
133    MaxVolBytes BIGINT UNSIGNED DEFAULT 0,
134    AutoPrune TINYINT DEFAULT 0,
135    Recycle TINYINT DEFAULT 0,
136    PoolType VARCHAR(20) NOT NULL,
137    LabelFormat VARCHAR(128) NOT NULL,
138    UNIQUE (Name),
139    PRIMARY KEY (PoolId)
140    );
141
142
143 CREATE TABLE Client (
144    ClientId INTEGER UNSIGNED AUTOINCREMENT,
145    Name VARCHAR(128) NOT NULL,
146    Uname VARCHAR(255) NOT NULL,   -- uname -a field
147    AutoPrune TINYINT DEFAULT 0,
148    FileRetention BIGINT UNSIGNED DEFAULT 0,
149    JobRetention  BIGINT UNSIGNED DEFAULT 0,
150    UNIQUE (Name),
151    PRIMARY KEY(ClientId)
152    );
153
154 CREATE TABLE NextId (
155    id INTEGER UNSIGNED DEFAULT 0,
156    TableName TEXT NOT NULL,
157    PRIMARY KEY (TableName)
158    );
159
160 -- Initialize JobId to start at 1
161 INSERT INTO NextId (id, TableName) VALUES (1, "Job");
162
163 CREATE TABLE Version (
164    VersionId INTEGER UNSIGNED NOT NULL 
165    );
166
167 -- Initialize Version            
168 INSERT INTO Version (VersionId) VALUES (4);
169
170 CREATE TABLE Counters (
171    Counter TEXT NOT NULL,     
172    PoolId INTEGER UNSIGNED REFERENCES Pool DEFAULT 0,
173    MinValue INTEGER DEFAULT 0, 
174    MaxValue INTEGER DEFAULT 0,
175    CurrentValue INTEGER DEFAULT 0,
176    WrapCounter TEXT NOT NULL,
177    PRIMARY KEY (Counter)
178    );
179
180 PRAGMA default_synchronous = OFF;
181 PRAGMA default_cache_size = 10000;
182
183 END-OF-DATA
184 exit 0