Imported Upstream version 0.6.0
[debian/confclerk.git] / src / dbschema000.sql
1 BEGIN TRANSACTION;
2 CREATE TABLE CONFERENCE ( id INTEGER PRIMARY KEY  AUTOINCREMENT  NOT NULL
3     , title VARCHAR UNIQUE NOT NULL
4     , subtitle VARCHAR
5     , venue VARCHAR
6     , city VARCHAR NOT NULL
7     , start INTEGER NOT NULL
8     , end INTEGER NOT NULL
9     , days INTEGER
10     , day_change INTEGER
11     , timeslot_duration INTEGER
12     , active INTEGER DEFAULT 0
13     , url VARCHAR);
14
15 CREATE TABLE TRACK ( id INTEGER  PRIMARY KEY AUTOINCREMENT  NOT NULL
16     , xid_conference INTEGER NOT NULL
17     , name VARCHAR NOT NULL
18     , UNIQUE (xid_conference, name));
19
20 CREATE TABLE ROOM ( id INTEGER PRIMARY KEY AUTOINCREMENT  NOT NULL
21     , xid_conference INTEGER NOT NULL
22     , name VARCHAR NOT NULL
23     , picture VARCHAR NOT NULL
24     , UNIQUE (xid_conference, name));
25
26 CREATE TABLE PERSON ( id INTEGER NOT NULL
27     , xid_conference INTEGER NOT NULL
28     , name VARCHAR NOT NULL
29     , UNIQUE (xid_conference, name)
30     , PRIMARY KEY (id, xid_conference)); 
31
32 CREATE TABLE EVENT ( xid_conference INTEGER  NOT NULL
33     , id INTEGER NOT NULL
34     , start INTEGER NOT NULL
35     , duration INTEGER NOT NULL -- duration of the event in seconds
36     , xid_track INTEGER NOT NULL REFERENCES TRACK(id)
37     , type VARCHAR
38     , language VARCHAR
39     , tag VARCHAR
40     , title VARCHAR NOT NULL
41     , subtitle VARCHAR
42     , abstract VARCHAR
43     , description VARCHAR
44     , favourite INTEGER DEFAULT 0
45     , alarm INTEGER DEFAULT 0
46     , PRIMARY KEY (xid_conference ,id)
47     , FOREIGN KEY(xid_conference) REFERENCES CONFERENCE(id)
48     , FOREIGN KEY(xid_track) REFERENCES TRACK(id));
49
50 CREATE TABLE EVENT_PERSON ( xid_conference INTEGER NOT NULL
51     , xid_event INTEGER NOT NULL
52     , xid_person INTEGER NOT NULL
53     , UNIQUE ( xid_conference , xid_event , xid_person ) ON CONFLICT REPLACE
54     , FOREIGN KEY(xid_conference) REFERENCES CONFERENCE(id)
55     , FOREIGN KEY(xid_conference, xid_event) REFERENCES EVENT(xid_conference, id)
56     , FOREIGN KEY(xid_conference, xid_person) REFERENCES PERSON(xid_conference, id));
57
58 CREATE TABLE EVENT_ROOM ( xid_conference INTEGER NOT NULL
59     , xid_event INTEGER NOT NULL
60     , xid_room INTEGER NOT NULL
61     , UNIQUE ( xid_conference , xid_event , xid_room ) ON CONFLICT REPLACE
62     , FOREIGN KEY(xid_conference) REFERENCES CONFERENCE(id)
63     , FOREIGN KEY(xid_conference, xid_event) REFERENCES EVENT(xid_conference, id)
64     , FOREIGN KEY(xid_conference, xid_room) REFERENCES ROOM(xid_conference, id));
65
66 CREATE TABLE LINK ( id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL
67     , xid_conference INTEGER NOT NULL
68     , xid_event INTEGER NOT NULL
69     , name VARCHAR
70     , url VARCHAR NOT NULL
71     , UNIQUE ( xid_conference , xid_event , url ) ON CONFLICT REPLACE
72     , FOREIGN KEY(xid_conference) REFERENCES CONFERENCE(id)
73     , FOREIGN KEY(xid_conference, xid_event) REFERENCES EVENT(xid_conference, id));
74 COMMIT;