-- Normalized httpd vhost
log -- Section 0. Decent defaults
PRAGMA page_size=4096;
PRAGMA default_cache_size=2048; -- = 8 MByte
PRAGMA cache_size=512;
PRAGMA foreign_keys=ON;
PRAGMA recursive_triggers=ON;
-- The table that would have been used for a 1:1 mapping of logfile to table
-- CREATE TABLE Loglines (
-- id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL
-- , id_log INTEGER
-- , linenr INTEGER
-- , vhost TEXT
-- , hhost TEXT
-- , client TEXT
-- , dtevent REAL
-- , method TEXT
-- , lpath TEXT
-- , lpage TEXT
-- , args TEXT
-- , rc INTEGER
-- , rsz INTEGER
-- , isz INTEGER
-- , osz INTEGER
-- );
-- Section 1. Referenced tables
-- 1.0
CREATE TABLE Categories (
id INTEGER PRIMARY KEY NOT NULL
, desc TEXT UNIQUE NOT NULL
);
INSERT INTO Categories (id,desc) VALUES (0,'unknown');
INSERT INTO Categories (id,desc) VALUES (1,'self');
INSERT INTO Categories (id,desc) VALUES (2,'meatwork');
INSERT INTO Categories (id,desc) VALUES (3,'family');
INSERT INTO Categories (id,desc) VALUES (4,'friend');
INSERT INTO Categories (id,desc) VALUES (5,'known');
INSERT INTO Categories (id,desc) VALUES (6,'hacker');
-- 1.1
CREATE TABLE Logs (
id INTEGER PRIMARY KEY NOT NULL
, filename TEXT UNIQUE NOT NULL
, dtimport REAL DEFAULT (julianday('now'))
, refcnt INTEGER DEFAULT 0 NOT NULL -- denormalized, maintained by trigger
-- , refchk INTEGER DEFAULT 0 -- denormalized, maintained by procedure
);
-- 1.2
CREATE TABLE Vhosts (
id INTEGER PRIMARY KEY NOT NULL
, vh TEXT UNIQUE NOT NULL -- abbreviation
, vhost TEXT UNIQUE NOT NULL -- full name_or_ip
, refcnt INTEGER DEFAULT 0 NOT NULL -- denormalized, maintained by trigger
-- , refchk INTEGER DEFAULT 0 -- denormalized, maintained by procedure
);
-- 1.3
CREATE TABLE Hhosts (
id INTEGER PRIMARY KEY NOT NULL
, hh TEXT NOT NULL -- abbreviation, may not be unique
, hhost TEXT UNIQUE NOT NULL -- full name_or_ip
, refcnt INTEGER DEFAULT 0 NOT NULL -- denormalized, maintained by trigger
-- , refchk INTEGER DEFAULT 0 -- denormalized, maintained by procedure
);
-- 1.4
CREATE TABLE Clients (
id INTEGER PRIMARY KEY NOT NULL
, client TEXT UNIQUE NOT NULL -- ipdotted
, ciip INTEGER
, refcnt INTEGER DEFAULT 0 NOT NULL -- denormalized, maintained by trigger
-- , refchk INTEGER DEFAULT 0 -- denormalized, maintained by procedure
);
-- 1.5
CREATE TABLE Users (
id INTEGER PRIMARY KEY NOT NULL
, user TEXT UNIQUE NOT NULL
, refcnt INTEGER DEFAULT 0 NOT NULL -- denormalized, maintained by trigger
-- , refchk INTEGER DEFAULT 0 -- denormalized, maintained by procedure
);
-- 1.6
CREATE TABLE Methods (
id INTEGER PRIMARY KEY NOT NULL
, method TEXT UNIQUE NOT NULL
, refcnt INTEGER DEFAULT 0 NOT NULL -- denormalized, maintained by trigger
-- , refchk INTEGER DEFAULT 0 -- denormalized, maintained by procedure
);
-- 1.7
CREATE TABLE Lpaths (
id INTEGER PRIMARY KEY NOT NULL
, lpath TEXT UNIQUE NOT NULL
, refcnt INTEGER DEFAULT 0 NOT NULL -- denormalized, maintained by trigger
-- , refchk INTEGER DEFAULT 0 -- denormalized, maintained by procedure
);
-- 1.8
CREATE TABLE Lpages (
id INTEGER PRIMARY KEY NOT NULL
, lpage TEXT UNIQUE NOT NULL
, refcnt INTEGER DEFAULT 0 NOT NULL -- denormalized, maintained by trigger
-- , refchk INTEGER DEFAULT 0 -- denormalized, maintained by procedure
);
-- 1.9
CREATE TABLE Argss (
id INTEGER PRIMARY KEY NOT NULL
, args TEXT UNIQUE NOT NULL
, refcnt INTEGER DEFAULT 0 NOT NULL -- denormalized, maintained by trigger
-- , refchk INTEGER DEFAULT 0 -- denormalized, maintained by procedure
);
-- prepopulate with empty strings
INSERT INTO Vhosts (vh,vhost) VALUES ('','');
INSERT INTO Hhosts (hh,hhost) VALUES ('','');
INSERT INTO Hhosts (hh,hhost) VALUES ('_lo0','localhost');
INSERT INTO Hhosts (hh,hhost) VALUES ('_lo4','127.0.0.1');
INSERT INTO Hhosts (hh,hhost) VALUES ('_lo6','::1');
INSERT INTO Hhosts (hh,hhost) VALUES ('_wan','1.2.3.4');
INSERT INTO Hhosts (hh,hhost) VALUES ('_lan','192.168.1.55');
INSERT INTO Clients (client,ciip) VALUES ('',0);
INSERT INTO Users (user) VALUES ('');
INSERT INTO Users (user) VALUES ('-');
INSERT INTO Methods (method) VALUES ('');
INSERT INTO Lpaths (lpath) VALUES ('');
INSERT INTO Lpages (lpage) VALUES ('');
INSERT INTO Argss (args) VALUES ('');
-- Section 2. Referencing tables
-- The main
log table mostly references the details.
CREATE TABLE T_Events (
id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL
, id_log INTEGER NOT NULL REFERENCES Logs (id) ON DELETE CASCADE ON UPDATE CASCADE
, linenr INTEGER NOT NULL
, id_vhost INTEGER NOT NULL REFERENCES Vhosts (id) ON DELETE CASCADE ON UPDATE CASCADE
, id_hhost INTEGER NOT NULL REFERENCES Hhosts (id) ON DELETE CASCADE ON UPDATE CASCADE
, id_client INTEGER NOT NULL REFERENCES Clients (id) ON DELETE CASCADE ON UPDATE CASCADE
, id_user INTEGER NOT NULL REFERENCES Users (id) ON DELETE CASCADE ON UPDATE CASCADE
, dtevent REAL
, id_method INTEGER NOT NULL REFERENCES Methods (id) ON DELETE CASCADE ON UPDATE CASCADE
, id_lpath INTEGER NOT NULL REFERENCES Lpaths (id) ON DELETE CASCADE ON UPDATE CASCADE
, id_lpage INTEGER NOT NULL REFERENCES Lpages (id) ON DELETE CASCADE ON UPDATE CASCADE
, id_args INTEGER NOT NULL REFERENCES Argss (id) ON DELETE CASCADE ON UPDATE CASCADE
, rc INTEGER
, rsz INTEGER
, isz INTEGER
, osz INTEGER
);
CREATE INDEX idx_te_dt on T_Events(dtevent);
-- Section 3. Updatable view that replaces that table
-- The view itself
CREATE VIEW Loglines AS
SELECT
E.id
, id_log
, linenr
, V.vhost
, H.hhost
, C.client
, C.ciip
, U.user
, dtevent
, M.method
, L.lpath
, P.lpage
, A.args
, rc
, rsz
, isz
, osz
FROM T_Events AS E
INNER JOIN Vhosts AS V ON (V.id==E.id_vhost)
INNER JOIN Hhosts AS H ON (H.id==E.id_hhost)
INNER JOIN Clients AS C ON (C.id==E.id_client)
INNER JOIN Users AS U ON (U.id==E.id_user)
INNER JOIN Methods AS M ON (M.id==E.id_method)
INNER JOIN Lpaths AS L ON (L.id==E.id_lpath)
INNER JOIN Lpages AS P ON (P.id==E.id_lpage)
INNER JOIN Argss AS A ON (A.id==E.id_args);
-- The trigger that defers the insert into view to insert in events, with all pointers looked up and filled in.
CREATE TRIGGER io_ins_Loglines INSTEAD OF INSERT ON Loglines
FOR EACH ROW
BEGIN
INSERT INTO T_Events (
id_log
, linenr
, id_vhost
, id_hhost
, id_client
, id_user
, dtevent
, id_method
, id_lpath
, id_lpage
, id_args
, rc
, rsz
, isz
, osz) VALUES (
NEW.id_log
, NEW.linenr
, (SELECT id FROM Vhosts WHERE vhost==NEW.vhost)
, (SELECT id FROM Hhosts WHERE hhost==NEW.hhost)
, (SELECT id FROM Clients WHERE client==NEW.client)
, (SELECT id FROM Users WHERE user==NEW.user)
, NEW.dtevent
, (SELECT id FROM Methods WHERE method==NEW.method)
, (SELECT id FROM Lpaths WHERE lpath==NEW.lpath)
, (SELECT id FROM Lpages WHERE lpage==NEW.lpage)
, (SELECT id FROM Argss WHERE args==NEW.args)
, NEW.rc
, NEW.rsz
, NEW.isz
, NEW.osz);
END;
-- Triggers for updating reference counters
-- speeds up reporting, slows down updates
CREATE TRIGGER a_ins_events AFTER INSERT ON T_Events
FOR EACH ROW
BEGIN
UPDATE Logs SET refcnt = refcnt + 1 WHERE id = NEW.id_log;
UPDATE Vhosts SET refcnt = refcnt + 1 WHERE id = NEW.id_vhost;
UPDATE Hhosts SET refcnt = refcnt + 1 WHERE id = NEW.id_hhost;
UPDATE Clients SET refcnt = refcnt + 1 WHERE id = NEW.id_client;
UPDATE Users SET refcnt = refcnt + 1 WHERE id = NEW.id_user;
UPDATE Methods SET refcnt = refcnt + 1 WHERE id = NEW.id_method;
UPDATE Lpaths SET refcnt = refcnt + 1 WHERE id = NEW.id_lpath;
UPDATE Lpages SET refcnt = refcnt + 1 WHERE id = NEW.id_lpage;
UPDATE Argss SET refcnt = refcnt + 1 WHERE id = NEW.id_args;
END;
CREATE TRIGGER a_del_events AFTER DELETE ON T_Events
FOR EACH ROW
BEGIN
UPDATE Logs SET refcnt = refcnt - 1 WHERE id = OLD.id_log;
UPDATE Vhosts SET refcnt = refcnt - 1 WHERE id = OLD.id_vhost;
UPDATE Hhosts SET refcnt = refcnt - 1 WHERE id = OLD.id_hhost;
UPDATE Clients SET refcnt = refcnt - 1 WHERE id = OLD.id_client;
UPDATE Users SET refcnt = refcnt - 1 WHERE id = OLD.id_user;
UPDATE Methods SET refcnt = refcnt - 1 WHERE id = OLD.id_method;
UPDATE Lpaths SET refcnt = refcnt - 1 WHERE id = OLD.id_lpath;
UPDATE Lpages SET refcnt = refcnt - 1 WHERE id = OLD.id_lpage;
UPDATE Argss SET refcnt = refcnt - 1 WHERE id = OLD.id_args;
END;
CREATE VIEW Abbrevloglines AS
SELECT
E.id
, id_log
, linenr
, V.vh
, H.hh
, H.hhost
, C.client
, U.user
, dtevent
, M.method
, L.lpath
, rc
, rsz
, isz
, osz
FROM T_Events AS E
INNER JOIN Vhosts AS V ON (V.id==E.id_vhost)
INNER JOIN Hhosts AS H ON (H.id==E.id_hhost)
INNER JOIN Clients AS C ON (C.id==E.id_client)
INNER JOIN Users AS U ON (U.id==E.id_user)
INNER JOIN Methods AS M ON (M.id==E.id_method)
INNER JOIN Lpaths AS L ON (L.id==E.id_lpath);
-- Section 4. Any other tables
-- Dates, can be used as Integers as well
CREATE TABLE Dates (
id INTEGER PRIMARY KEY NOT NULL
, d REAL
);
CREATE TABLE KnownIPs (
ipdotted TEXT PRIMARY KEY NOT NULL
, owner TEXT DEFAULT 'knuyt'
, id_cat INTEGER NOT NULL DEFAULT 0 REFERENCES Categories (id) ON DELETE CASCADE ON UPDATE CASCADE
);
-- EOF
-- Normalized httpd vhost log
-- Section 0. Decent defaults
PRAGMA page_size=4096;
PRAGMA default_cache_size=2048; -- = 8 MByte
PRAGMA cache_size=512;
PRAGMA foreign_keys=ON;
PRAGMA recursive_triggers=ON;
--    The table that would have been used for a 1:1 mapping of logfile to table
--		CREATE TABLE Loglines (
--			id         INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL
--		,	id_log     INTEGER
--		,	linenr     INTEGER
--		,	vhost      TEXT
--		,	hhost      TEXT
--		,	client     TEXT
--		,	dtevent    REAL
--		,	method     TEXT
--		,	lpath      TEXT
--		,	lpage      TEXT
--		,	args       TEXT
--		,	rc         INTEGER
--		,	rsz        INTEGER
--		,	isz        INTEGER
--		,	osz        INTEGER
--		);

-- Section 1. Referenced tables
-- 1.0
CREATE TABLE Categories (
	id         INTEGER PRIMARY KEY NOT NULL
,	desc       TEXT UNIQUE NOT NULL
);

INSERT INTO Categories (id,desc) VALUES (0,'unknown');
INSERT INTO Categories (id,desc) VALUES (1,'self');
INSERT INTO Categories (id,desc) VALUES (2,'meatwork');
INSERT INTO Categories (id,desc) VALUES (3,'family');
INSERT INTO Categories (id,desc) VALUES (4,'friend');
INSERT INTO Categories (id,desc) VALUES (5,'known');
INSERT INTO Categories (id,desc) VALUES (6,'hacker');

-- 1.1
CREATE TABLE Logs (
	id INTEGER PRIMARY KEY NOT NULL
,	filename   TEXT UNIQUE NOT NULL
,	dtimport   REAL DEFAULT (julianday('now'))
,	refcnt     INTEGER DEFAULT 0 NOT NULL  -- denormalized, maintained by trigger
-- ,	refchk     INTEGER DEFAULT 0           -- denormalized, maintained by procedure
);
-- 1.2
CREATE TABLE Vhosts (
	id INTEGER PRIMARY KEY NOT NULL
,	vh         TEXT UNIQUE NOT NULL        -- abbreviation
,	vhost      TEXT UNIQUE NOT NULL        -- full name_or_ip
,	refcnt     INTEGER DEFAULT 0 NOT NULL  -- denormalized, maintained by trigger
-- ,	refchk     INTEGER DEFAULT 0           -- denormalized, maintained by procedure
);
-- 1.3
CREATE TABLE Hhosts (
	id INTEGER PRIMARY KEY NOT NULL
,	hh         TEXT        NOT NULL        -- abbreviation, may not be unique
,	hhost      TEXT UNIQUE NOT NULL        -- full name_or_ip
,	refcnt     INTEGER DEFAULT 0 NOT NULL  -- denormalized, maintained by trigger
--	,	refchk     INTEGER DEFAULT 0           -- denormalized, maintained by procedure
);
-- 1.4
CREATE TABLE Clients (
	id INTEGER PRIMARY KEY NOT NULL
,	client     TEXT UNIQUE NOT NULL        -- ipdotted
,	ciip       INTEGER
,	refcnt     INTEGER DEFAULT 0 NOT NULL  -- denormalized, maintained by trigger
--	,	refchk     INTEGER DEFAULT 0           -- denormalized, maintained by procedure
);
-- 1.5
CREATE TABLE Users (
	id INTEGER PRIMARY KEY NOT NULL
,	user       TEXT UNIQUE NOT NULL
,	refcnt     INTEGER DEFAULT 0 NOT NULL  -- denormalized, maintained by trigger
--	,	refchk     INTEGER DEFAULT 0           -- denormalized, maintained by procedure
);
-- 1.6
CREATE TABLE Methods (
	id INTEGER PRIMARY KEY NOT NULL
,	method     TEXT UNIQUE NOT NULL
,	refcnt     INTEGER DEFAULT 0 NOT NULL  -- denormalized, maintained by trigger
--	,	refchk     INTEGER DEFAULT 0           -- denormalized, maintained by procedure
);
-- 1.7
CREATE TABLE Lpaths (
	id INTEGER PRIMARY KEY NOT NULL
,	lpath      TEXT UNIQUE NOT NULL
,	refcnt     INTEGER DEFAULT 0 NOT NULL  -- denormalized, maintained by trigger
--	,	refchk     INTEGER DEFAULT 0           -- denormalized, maintained by procedure
);
-- 1.8
CREATE TABLE Lpages (
	id INTEGER PRIMARY KEY NOT NULL
,	lpage      TEXT UNIQUE NOT NULL
,	refcnt     INTEGER DEFAULT 0 NOT NULL  -- denormalized, maintained by trigger
--	,	refchk     INTEGER DEFAULT 0           -- denormalized, maintained by procedure
);
-- 1.9
CREATE TABLE Argss (
	id INTEGER PRIMARY KEY NOT NULL
,	args       TEXT UNIQUE NOT NULL
,	refcnt     INTEGER DEFAULT 0 NOT NULL  -- denormalized, maintained by trigger
--	,	refchk     INTEGER DEFAULT 0           -- denormalized, maintained by procedure
);

-- prepopulate with empty strings
INSERT INTO Vhosts  (vh,vhost)    VALUES ('','');
INSERT INTO Hhosts  (hh,hhost)    VALUES ('','');
INSERT INTO Hhosts  (hh,hhost)    VALUES ('_lo0','localhost');
INSERT INTO Hhosts  (hh,hhost)    VALUES ('_lo4','127.0.0.1');
INSERT INTO Hhosts  (hh,hhost)    VALUES ('_lo6','::1');
INSERT INTO Hhosts  (hh,hhost)    VALUES ('_wan','1.2.3.4');
INSERT INTO Hhosts  (hh,hhost)    VALUES ('_lan','192.168.1.55');
INSERT INTO Clients (client,ciip) VALUES ('',0);
INSERT INTO Users   (user)        VALUES ('');
INSERT INTO Users   (user)        VALUES ('-');
INSERT INTO Methods (method)      VALUES ('');
INSERT INTO Lpaths  (lpath)       VALUES ('');
INSERT INTO Lpages  (lpage)       VALUES ('');
INSERT INTO Argss   (args)        VALUES ('');

-- Section 2. Referencing tables
--    The main log table mostly references the details.
CREATE TABLE T_Events (
	id           INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL
,	id_log       INTEGER NOT NULL REFERENCES Logs    (id) ON DELETE CASCADE ON UPDATE CASCADE
,	linenr       INTEGER NOT NULL
,	id_vhost     INTEGER NOT NULL REFERENCES Vhosts  (id) ON DELETE CASCADE ON UPDATE CASCADE
,	id_hhost     INTEGER NOT NULL REFERENCES Hhosts  (id) ON DELETE CASCADE ON UPDATE CASCADE
,	id_client    INTEGER NOT NULL REFERENCES Clients (id) ON DELETE CASCADE ON UPDATE CASCADE
,	id_user      INTEGER NOT NULL REFERENCES Users   (id) ON DELETE CASCADE ON UPDATE CASCADE
,	dtevent      REAL
,	id_method    INTEGER NOT NULL REFERENCES Methods (id) ON DELETE CASCADE ON UPDATE CASCADE
,	id_lpath     INTEGER NOT NULL REFERENCES Lpaths  (id) ON DELETE CASCADE ON UPDATE CASCADE
,	id_lpage     INTEGER NOT NULL REFERENCES Lpages  (id) ON DELETE CASCADE ON UPDATE CASCADE
,	id_args      INTEGER NOT NULL REFERENCES Argss   (id) ON DELETE CASCADE ON UPDATE CASCADE
,	rc           INTEGER
,	rsz          INTEGER
,	isz          INTEGER
,	osz          INTEGER
);

CREATE INDEX idx_te_dt on T_Events(dtevent);

-- Section 3. Updatable view that replaces that table
--    The view itself
CREATE VIEW Loglines AS 
  SELECT 
	E.id
,	id_log
,	linenr
,	V.vhost
,	H.hhost
,	C.client
,	C.ciip
,	U.user
,	dtevent
,	M.method
,	L.lpath
,	P.lpage
,	A.args
,	rc
,	rsz
,	isz
,	osz
	FROM T_Events AS E
	INNER JOIN Vhosts    AS V ON (V.id==E.id_vhost)
	INNER JOIN Hhosts    AS H ON (H.id==E.id_hhost)
	INNER JOIN Clients   AS C ON (C.id==E.id_client)
	INNER JOIN Users     AS U ON (U.id==E.id_user)
	INNER JOIN Methods   AS M ON (M.id==E.id_method)
	INNER JOIN Lpaths    AS L ON (L.id==E.id_lpath)
	INNER JOIN Lpages    AS P ON (P.id==E.id_lpage)
	INNER JOIN Argss     AS A ON (A.id==E.id_args);

--    The trigger that defers the insert into view to insert in events, with all pointers looked up and filled in.
CREATE TRIGGER io_ins_Loglines INSTEAD OF INSERT ON Loglines
FOR EACH ROW
BEGIN
	INSERT INTO T_Events (
	id_log
,	linenr
,	id_vhost
,	id_hhost
,	id_client
,	id_user
,	dtevent
,	id_method
,	id_lpath
,	id_lpage
,	id_args
,	rc
,	rsz
,	isz
,	osz) VALUES (
	NEW.id_log
,	NEW.linenr
,	(SELECT id FROM Vhosts  WHERE  vhost==NEW.vhost)
,	(SELECT id FROM Hhosts  WHERE  hhost==NEW.hhost)
,	(SELECT id FROM Clients WHERE client==NEW.client)
,	(SELECT id FROM Users   WHERE   user==NEW.user)
,	NEW.dtevent
,	(SELECT id FROM Methods WHERE method==NEW.method)
,	(SELECT id FROM Lpaths  WHERE  lpath==NEW.lpath)
,	(SELECT id FROM Lpages  WHERE  lpage==NEW.lpage)
,	(SELECT id FROM Argss   WHERE   args==NEW.args)
,	NEW.rc
,	NEW.rsz
,	NEW.isz
,	NEW.osz);
END;

-- Triggers for updating reference counters
-- speeds up reporting, slows down updates

CREATE TRIGGER a_ins_events AFTER INSERT ON T_Events
FOR EACH ROW
BEGIN
	UPDATE Logs    SET refcnt = refcnt + 1 WHERE id = NEW.id_log;
	UPDATE Vhosts  SET refcnt = refcnt + 1 WHERE id = NEW.id_vhost;
	UPDATE Hhosts  SET refcnt = refcnt + 1 WHERE id = NEW.id_hhost;
	UPDATE Clients SET refcnt = refcnt + 1 WHERE id = NEW.id_client;
	UPDATE Users   SET refcnt = refcnt + 1 WHERE id = NEW.id_user;
	UPDATE Methods SET refcnt = refcnt + 1 WHERE id = NEW.id_method;
	UPDATE Lpaths  SET refcnt = refcnt + 1 WHERE id = NEW.id_lpath;
	UPDATE Lpages  SET refcnt = refcnt + 1 WHERE id = NEW.id_lpage;
	UPDATE Argss   SET refcnt = refcnt + 1 WHERE id = NEW.id_args;
END;

CREATE TRIGGER a_del_events AFTER DELETE ON T_Events
FOR EACH ROW
BEGIN
	UPDATE Logs    SET refcnt = refcnt - 1 WHERE id = OLD.id_log;
	UPDATE Vhosts  SET refcnt = refcnt - 1 WHERE id = OLD.id_vhost;
	UPDATE Hhosts  SET refcnt = refcnt - 1 WHERE id = OLD.id_hhost;
	UPDATE Clients SET refcnt = refcnt - 1 WHERE id = OLD.id_client;
	UPDATE Users   SET refcnt = refcnt - 1 WHERE id = OLD.id_user;
	UPDATE Methods SET refcnt = refcnt - 1 WHERE id = OLD.id_method;
	UPDATE Lpaths  SET refcnt = refcnt - 1 WHERE id = OLD.id_lpath;
	UPDATE Lpages  SET refcnt = refcnt - 1 WHERE id = OLD.id_lpage;
	UPDATE Argss   SET refcnt = refcnt - 1 WHERE id = OLD.id_args;
END;

CREATE VIEW Abbrevloglines AS 
  SELECT 
	E.id
,	id_log
,	linenr
,	V.vh
,	H.hh
,	H.hhost
,	C.client
,	U.user
,	dtevent
,	M.method
,	L.lpath
,	rc
,	rsz
,	isz
,	osz
	FROM T_Events AS E
	INNER JOIN Vhosts    AS V ON (V.id==E.id_vhost)
	INNER JOIN Hhosts    AS H ON (H.id==E.id_hhost)
	INNER JOIN Clients   AS C ON (C.id==E.id_client)
	INNER JOIN Users     AS U ON (U.id==E.id_user)
	INNER JOIN Methods   AS M ON (M.id==E.id_method)
	INNER JOIN Lpaths    AS L ON (L.id==E.id_lpath);

-- Section 4. Any other tables
--    Dates, can be used as Integers as well
CREATE TABLE Dates (
	id INTEGER PRIMARY KEY  NOT NULL
,	d          REAL
);

CREATE TABLE KnownIPs (
	ipdotted   TEXT PRIMARY KEY NOT NULL
,	owner      TEXT DEFAULT 'knuyt'
,	id_cat     INTEGER NOT NULL DEFAULT 0 REFERENCES Categories (id) ON DELETE CASCADE ON UPDATE CASCADE
);

-- EOF