]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/cats/make_sqlite_tables.in
31b29ec9f690b1395cfe90c8350a471b29222963
[bacula/bacula] / bacula / src / cats / make_sqlite_tables.in
1 #!/bin/sh
2 #
3 # shell script to create Bacula 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    LStat VARCHAR(255) NOT NULL,
29    MD5 VARCHAR(25) NOT NULL,
30    PRIMARY KEY(FileId) 
31    );
32
33 CREATE TABLE Job (
34    JobId INTEGER UNSIGNED NOT NULL,
35    Job VARCHAR(128) NOT NULL,
36    Name VARCHAR(128) NOT NULL,
37    PurgedFiles TINYINT DEFAULT 0,
38    Type CHAR NOT NULL,
39    Level CHAR NOT NULL,
40    ClientId INTEGER REFERENCES Client DEFAULT 0,
41    JobStatus CHAR,
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,
54    PRIMARY KEY(JobId) 
55    );
56
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)
62    );
63
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) 
75    );
76
77
78 CREATE TABLE Media (
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,
98    PRIMARY KEY(MediaId)
99    );
100
101 CREATE TABLE Pool (
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,
114    UNIQUE (Name),
115    PRIMARY KEY (PoolId)
116    );
117
118
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,
126    UNIQUE (Name),
127    PRIMARY KEY(ClientId)
128    );
129
130 CREATE TABLE NextId (
131    id INTEGER UNSIGNED DEFAULT 0,
132    TableName TEXT NOT NULL,
133    PRIMARY KEY (TableName)
134    );
135
136 -- Initialize JobId to start at 1
137 INSERT INTO NextId (id, TableName) VALUES (1, "Job");
138
139 CREATE TABLE Version (
140    VersionId INTEGER UNSIGNED NOT NULL 
141    );
142
143 -- Initialize Version            
144 INSERT INTO Version (VersionId) VALUES (1);
145
146
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,
155    PRIMARY KEY(FileId) 
156    );
157
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,
163    PRIMARY KEY(FileId) 
164    );
165
166
167 END-OF-DATA
168 exit 0