3 # shell script to create Bacula SQLite tables
8 $bindir/sqlite bacula.db <<END-OF-DATA
9 CREATE TABLE Filename (
10 FilenameId INTEGER UNSIGNED AUTOINCREMENT,
12 PRIMARY KEY(FilenameId)
15 CREATE INDEX inx1 ON Filename (Name);
18 PathId INTEGER UNSIGNED AUTOINCREMENT,
23 CREATE INDEX inx2 ON Path (Path);
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,
38 CREATE INDEX inx3 ON File (JobId);
39 CREATE INDEX inx4 ON File (PathId);
40 CREATE INDEX inx5 ON File (FileNameId);
43 JobId INTEGER UNSIGNED NOT NULL,
44 Job VARCHAR(128) NOT NULL,
45 Name VARCHAR(128) NOT NULL,
46 PurgedFiles TINYINT DEFAULT 0,
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,
66 CREATE INDEX inx6 ON Job (Name);
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)
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)
88 CREATE INDEX inx7 ON JobMedia (JobId, MediaId);
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,
119 CREATE INDEX inx8 ON Media (PoolId);
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,
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,
151 PRIMARY KEY(ClientId)
154 CREATE TABLE NextId (
155 id INTEGER UNSIGNED DEFAULT 0,
156 TableName TEXT NOT NULL,
157 PRIMARY KEY (TableName)
160 -- Initialize JobId to start at 1
161 INSERT INTO NextId (id, TableName) VALUES (1, "Job");
163 CREATE TABLE Version (
164 VersionId INTEGER UNSIGNED NOT NULL
167 -- Initialize Version
168 INSERT INTO Version (VersionId) VALUES (5);
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)
180 PRAGMA default_synchronous = OFF;
181 PRAGMA default_cache_size = 10000;