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)
16 PathId INTEGER UNSIGNED AUTOINCREMENT,
23 FileId INTEGER UNSIGNED AUTOINCREMENT,
24 FileIndex INTEGER UNSIGNED NOT NULL,
25 JobId INTEGER UNSIGNED REFERENCES Job NOT NULL,
26 PathId INTEGER UNSIGNED REFERENCES Path NOT NULL,
27 FilenameId INTEGER REFERENCES Filename NOT NULL,
28 MarkId INTEGER UNSIGNED DEFAULT 0,
29 LStat VARCHAR(255) NOT NULL,
30 MD5 VARCHAR(25) NOT NULL,
35 JobId INTEGER UNSIGNED NOT NULL,
36 Job VARCHAR(128) NOT NULL,
37 Name VARCHAR(128) NOT NULL,
38 PurgedFiles TINYINT DEFAULT 0,
41 ClientId INTEGER REFERENCES Client DEFAULT 0,
43 SchedTime DATETIME NOT NULL,
44 StartTime DATETIME DEFAULT 0,
45 EndTime DATETIME DEFAULT 0,
46 JobTDate BIGINT UNSIGNED DEFAULT 0,
47 VolSessionId INTEGER UNSIGNED DEFAULT 0,
48 VolSessionTime INTEGER UNSIGNED DEFAULT 0,
49 JobFiles INTEGER UNSIGNED DEFAULT 0,
50 JobBytes BIGINT UNSIGNED DEFAULT 0,
51 JobErrors INTEGER UNSIGNED DEFAULT 0,
52 JobMissingFiles INTEGER UNSIGNED DEFAULT 0,
53 PoolId INTEGER UNSIGNED REFERENCES Pool DEFAULT 0,
54 FileSetId INTEGER UNSIGNED REFERENCES FileSet DEFAULT 0,
58 CREATE TABLE FileSet (
59 FileSetId INTEGER UNSIGNED AUTOINCREMENT,
60 FileSet VARCHAR(128) NOT NULL,
61 MD5 VARCHAR(25) NOT NULL,
62 PRIMARY KEY(FileSetId)
65 CREATE TABLE JobMedia (
66 JobMediaId INTEGER UNSIGNED AUTOINCREMENT,
67 JobId INTEGER UNSIGNED REFERENCES Job NOT NULL,
68 MediaId INTEGER UNSIGNED REFERENCES Media NOT NULL,
69 FirstIndex INTEGER UNSIGNED NOT NULL,
70 LastIndex INTEGER UNSIGNED NOT NULL,
71 StartFile INTEGER UNSIGNED DEFAULT 0,
72 EndFile INTEGER UNSIGNED DEFAULT 0,
73 StartBlock INTEGER UNSIGNED DEFAULT 0,
74 EndBlock INTEGER UNSIGNED DEFAULT 0,
75 PRIMARY KEY(JobMediaId)
80 MediaId INTEGER UNSIGNED AUTOINCREMENT,
81 VolumeName VARCHAR(128) NOT NULL,
82 Slot INTEGER DEFAULT 0,
83 PoolId INTEGER UNSIGNED REFERENCES Pool NOT NULL,
84 MediaType VARCHAR(128) NOT NULL,
85 FirstWritten DATETIME DEFAULT 0,
86 LastWritten DATETIME DEFAULT 0,
87 LabelDate DATETIME DEFAULT 0,
88 VolJobs INTEGER UNSIGNED DEFAULT 0,
89 VolFiles INTEGER UNSIGNED DEFAULT 0,
90 VolBlocks INTEGER UNSIGNED DEFAULT 0,
91 VolMounts INTEGER UNSIGNED DEFAULT 0,
92 VolBytes BIGINT UNSIGNED DEFAULT 0,
93 VolErrors INTEGER UNSIGNED DEFAULT 0,
94 VolWrites INTEGER UNSIGNED DEFAULT 0,
95 VolMaxBytes BIGINT UNSIGNED DEFAULT 0,
96 VolCapacityBytes BIGINT UNSIGNED DEFAULT 0,
97 VolStatus VARCHAR(20) NOT NULL,
98 Recycle TINYINT DEFAULT 0,
99 VolRetention BIGINT UNSIGNED DEFAULT 0,
104 PoolId INTEGER UNSIGNED AUTOINCREMENT,
105 Name VARCHAR(128) NOT NULL,
106 NumVols INTEGER UNSIGNED DEFAULT 0,
107 MaxVols INTEGER UNSIGNED DEFAULT 0,
108 UseOnce TINYINT DEFAULT 0,
109 UseCatalog TINYINT DEFAULT 1,
110 AcceptAnyVolume TINYINT DEFAULT 0,
111 VolRetention BIGINT UNSIGNED DEFAULT 0,
112 AutoPrune TINYINT DEFAULT 0,
113 Recycle TINYINT DEFAULT 0,
114 PoolType VARCHAR(20) NOT NULL,
115 LabelFormat VARCHAR(128) NOT NULL,
121 CREATE TABLE Client (
122 ClientId INTEGER UNSIGNED AUTOINCREMENT,
123 Name VARCHAR(128) NOT NULL,
124 Uname VARCHAR(255) NOT NULL, -- uname -a field
125 AutoPrune TINYINT DEFAULT 0,
126 FileRetention BIGINT UNSIGNED DEFAULT 0,
127 JobRetention BIGINT UNSIGNED DEFAULT 0,
129 PRIMARY KEY(ClientId)
132 CREATE TABLE NextId (
133 id INTEGER UNSIGNED DEFAULT 0,
134 TableName TEXT NOT NULL,
135 PRIMARY KEY (TableName)
138 -- Initialize JobId to start at 1
139 INSERT INTO NextId (id, TableName) VALUES (1, "Job");
141 CREATE TABLE Version (
142 VersionId INTEGER UNSIGNED NOT NULL
145 -- Initialize Version
146 INSERT INTO Version (VersionId) VALUES (2);
148 CREATE TABLE Counters (
149 Counter TEXT NOT NULL,
150 PoolId INTEGER UNSIGNED REFERENCES Pool DEFAULT 0,
151 MinValue INTEGER DEFAULT 0,
152 MaxValue INTEGER DEFAULT 0,
153 CurrentValue INTEGER DEFAULT 0,
154 WrapCounter TEXT NOT NULL,
155 PRIMARY KEY (Counter)
158 PRAGMA default_synchronous=OFF;