]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/cats/make_sqlite_tables.in
SQLite performance + misc -- see kes20Jul02
[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 TABLE Path (
16    PathId INTEGER UNSIGNED AUTOINCREMENT,
17    Path TEXT DEFAULT "",
18    PRIMARY KEY(PathId) 
19    );
20
21
22 CREATE TABLE File (
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,
31    PRIMARY KEY(FileId) 
32    );
33
34 CREATE TABLE Job (
35    JobId INTEGER UNSIGNED NOT NULL,
36    Job VARCHAR(128) NOT NULL,
37    Name VARCHAR(128) NOT NULL,
38    PurgedFiles TINYINT DEFAULT 0,
39    Type CHAR NOT NULL,
40    Level CHAR NOT NULL,
41    ClientId INTEGER REFERENCES Client DEFAULT 0,
42    JobStatus CHAR NOT NULL,
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,
55    PRIMARY KEY(JobId) 
56    );
57
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)
63    );
64
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) 
76    );
77
78
79 CREATE TABLE Media (
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,
100    PRIMARY KEY(MediaId)
101    );
102
103 CREATE TABLE Pool (
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,
116    UNIQUE (Name),
117    PRIMARY KEY (PoolId)
118    );
119
120
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,
128    UNIQUE (Name),
129    PRIMARY KEY(ClientId)
130    );
131
132 CREATE TABLE NextId (
133    id INTEGER UNSIGNED DEFAULT 0,
134    TableName TEXT NOT NULL,
135    PRIMARY KEY (TableName)
136    );
137
138 -- Initialize JobId to start at 1
139 INSERT INTO NextId (id, TableName) VALUES (1, "Job");
140
141 CREATE TABLE Version (
142    VersionId INTEGER UNSIGNED NOT NULL 
143    );
144
145 -- Initialize Version            
146 INSERT INTO Version (VersionId) VALUES (2);
147
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)
156    );
157
158 PRAGMA default_synchronous = OFF;
159 PRAGMA default_cache_size = 10000;
160
161 END-OF-DATA
162 exit 0