3 # shell script to create Bacula 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 LStat VARCHAR(255) NOT NULL,
29 MD5 VARCHAR(25) NOT NULL,
34 JobId INTEGER UNSIGNED NOT NULL,
35 Job VARCHAR(128) NOT NULL,
36 Name VARCHAR(128) NOT NULL,
37 PurgedFiles TINYINT DEFAULT 0,
40 ClientId INTEGER REFERENCES Client DEFAULT 0,
42 SchedTime DATETIME NOT NULL,
43 StartTime DATETIME DEFAULT 0,
44 EndTime DATETIME DEFAULT 0,
45 JobTDate BIGINT UNSIGNED DEFAULT 0,
46 VolSessionId INTEGER UNSIGNED DEFAULT 0,
47 VolSessionTime INTEGER UNSIGNED DEFAULT 0,
48 JobFiles INTEGER UNSIGNED DEFAULT 0,
49 JobBytes BIGINT UNSIGNED DEFAULT 0,
50 JobErrors INTEGER UNSIGNED DEFAULT 0,
51 JobMissingFiles INTEGER UNSIGNED DEFAULT 0,
52 PoolId INTEGER UNSIGNED REFERENCES Pool DEFAULT 0,
53 FileSetId INTEGER UNSIGNED REFERENCES FileSet DEFAULT 0,
57 CREATE TABLE FileSet (
58 FileSetId INTEGER UNSIGNED AUTOINCREMENT,
59 FileSet VARCHAR(128) NOT NULL,
60 MD5 VARCHAR(25) NOT NULL,
61 PRIMARY KEY(FileSetId)
64 CREATE TABLE JobMedia (
65 JobMediaId INTEGER UNSIGNED AUTOINCREMENT,
66 JobId INTEGER UNSIGNED REFERENCES Job NOT NULL,
67 MediaId INTEGER UNSIGNED REFERENCES Media NOT NULL,
68 FirstIndex INTEGER UNSIGNED NOT NULL,
69 LastIndex INTEGER UNSIGNED NOT NULL,
70 StartFile INTEGER UNSIGNED DEFAULT 0,
71 EndFile INTEGER UNSIGNED DEFAULT 0,
72 StartBlock INTEGER UNSIGNED DEFAULT 0,
73 EndBlock INTEGER UNSIGNED DEFAULT 0,
74 PRIMARY KEY(JobMediaId)
79 MediaId INTEGER UNSIGNED AUTOINCREMENT,
80 VolumeName VARCHAR(128) NOT NULL,
81 PoolId INTEGER UNSIGNED REFERENCES Pool NOT NULL,
82 MediaType VARCHAR(128) NOT NULL,
83 FirstWritten DATETIME DEFAULT 0,
84 LastWritten DATETIME DEFAULT 0,
85 LabelDate DATETIME DEFAULT 0,
86 VolJobs INTEGER UNSIGNED DEFAULT 0,
87 VolFiles INTEGER UNSIGNED DEFAULT 0,
88 VolBlocks INTEGER UNSIGNED DEFAULT 0,
89 VolMounts INTEGER UNSIGNED DEFAULT 0,
90 VolBytes BIGINT UNSIGNED DEFAULT 0,
91 VolErrors INTEGER UNSIGNED DEFAULT 0,
92 VolWrites INTEGER UNSIGNED DEFAULT 0,
93 VolMaxBytes BIGINT UNSIGNED DEFAULT 0,
94 VolCapacityBytes BIGINT UNSIGNED DEFAULT 0,
95 VolStatus VARCHAR(20) NOT NULL,
96 Recycle TINYINT DEFAULT 0,
97 VolRetention BIGINT UNSIGNED DEFAULT 0,
102 PoolId INTEGER UNSIGNED AUTOINCREMENT,
103 Name VARCHAR(128) NOT NULL,
104 NumVols INTEGER UNSIGNED DEFAULT 0,
105 MaxVols INTEGER UNSIGNED DEFAULT 0,
106 UseOnce TINYINT DEFAULT 0,
107 UseCatalog TINYINT DEFAULT 1,
108 AcceptAnyVolume TINYINT DEFAULT 0,
109 VolRetention BIGINT UNSIGNED DEFAULT 0,
110 AutoPrune TINYINT DEFAULT 0,
111 Recycle TINYINT DEFAULT 0,
112 PoolType VARCHAR(20) NOT NULL,
113 LabelFormat VARCHAR(128) NOT NULL,
119 CREATE TABLE Client (
120 ClientId INTEGER UNSIGNED AUTOINCREMENT,
121 Name VARCHAR(128) NOT NULL,
122 Uname VARCHAR(255) NOT NULL, -- uname -a field
123 AutoPrune TINYINT DEFAULT 0,
124 FileRetention BIGINT UNSIGNED DEFAULT 0,
125 JobRetention BIGINT UNSIGNED DEFAULT 0,
127 PRIMARY KEY(ClientId)
130 CREATE TABLE NextId (
131 id INTEGER UNSIGNED DEFAULT 0,
132 TableName TEXT NOT NULL,
133 PRIMARY KEY (TableName)
136 -- Initialize JobId to start at 1
137 INSERT INTO NextId (id, TableName) VALUES (1, "Job");
139 CREATE TABLE Version (
140 VersionId INTEGER UNSIGNED NOT NULL
143 -- Initialize Version
144 INSERT INTO Version (VersionId) VALUES (1);
147 -- Experimental stuff below. Not used.
148 -- Invariant part of File
149 CREATE TABLE BaseFile (
150 FileId INTEGER UNSIGNED AUTOINCREMENT,
151 PathId INTEGER UNSIGNED REFERENCES Path NOT NULL,
152 FilenameId INTEGER REFERENCES Filename NOT NULL,
153 LStat VARCHAR(255) NOT NULL,
154 MD5 VARCHAR(25) NOT NULL,
158 -- Variable part of File
159 CREATE TABLE FileSave (
160 FileId INTEGER UNSIGNED REFERENCES BaseFile NOT NULL,
161 FileIndex INTEGER UNSIGNED NOT NULL,
162 JobId INTEGER UNSIGNED REFERENCES Job NOT NULL,