]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/cats/make_sqlite_tables.in
1.19 24Apr02
[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    StartDay INTEGER 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 VARCHAR(20) NOT NULL,
97    PRIMARY KEY(MediaId)
98    );
99
100 CREATE TABLE Pool (
101    PoolId INTEGER UNSIGNED AUTOINCREMENT,
102    Name VARCHAR(128) NOT NULL,
103    NumVols INTEGER UNSIGNED NOT NULL,
104    MaxVols INTEGER UNSIGNED NOT NULL,
105    UseOnce TINYINT NOT NULL,
106    UseCatalog TINYINT NOT NULL,
107    AcceptAnyVolume TINYINT NOT NULL,
108    PoolType VARCHAR(20) NOT NULL,
109    LabelFormat VARCHAR(128) NOT NULL,
110    UNIQUE (Name),
111    PRIMARY KEY (PoolId)
112    );
113
114
115 CREATE TABLE Client (
116    ClientId INTEGER UNSIGNED AUTOINCREMENT,
117    Name VARCHAR(128) NOT NULL,
118    Uname VARCHAR(255) NOT NULL,   -- uname -a field
119    UNIQUE (Name),
120    PRIMARY KEY(ClientId)
121    );
122
123 CREATE TABLE NextId (
124    id INTEGER UNSIGNED DEFAULT 0,
125    TableName TEXT NOT NULL,
126    PRIMARY KEY (TableName)
127    );
128
129 -- Initialize JobId to start at 1
130 INSERT INTO NextId (id, TableName) VALUES (1, "Job");
131
132 -- Experimental stuff below. Not used.
133 -- Invariant part of File
134 CREATE TABLE BaseFile (
135    FileId INTEGER UNSIGNED AUTOINCREMENT,
136    PathId INTEGER UNSIGNED REFERENCES Path NOT NULL,
137    FilenameId INTEGER REFERENCES Filename NOT NULL,
138    LStat VARCHAR(255) NOT NULL,
139    MD5 VARCHAR(25) NOT NULL,
140    PRIMARY KEY(FileId) 
141    );
142
143 -- Variable part of File
144 CREATE TABLE FileSave (
145    FileId INTEGER UNSIGNED REFERENCES BaseFile NOT NULL,
146    FileIndex INTEGER UNSIGNED NOT NULL,
147    JobId INTEGER UNSIGNED REFERENCES Job NOT NULL,
148    PRIMARY KEY(FileId) 
149    );
150
151
152 END-OF-DATA
153 exit 0