-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathschema.sql
113 lines (97 loc) · 2.61 KB
/
schema.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
CREATE TABLE courses (
course_id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
crn VARCHAR NOT NULL,
dept_id int REFERENCES departments,
course_number NOT NULL,
time_id int NOT NULL REFERENCES times,
theme_id int NOT NULL REFERENCES themes,
faculty_id int REFERENCES faculty,
preassn_mentor_id int REFERENCES mentors,
online_hybrid boolean NOT NULL
);
CREATE TABLE faculty (
faculty_id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
faculty_name varchar NOT NULL UNIQUE
);
CREATE TABLE faculty_weight_value (
weight int NOT NULL PRIMARY KEY,
value float NOT NULL
);
CREATE TABLE mentors (
mentor_id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
returning boolean NOT NULL ,
online_hybrid boolean NOT NULL ,
odin_id varchar NOT NULL ,
full_name varchar NOT NULL ,
slots_available int NOT NULL ,
owning_dept INT REFERENCES DEPARTMENTS,
email varchar NOT NULL
);
CREATE TABLE mentor_time_pref (
mentor_id int NOT NULL REFERENCES mentors,
time_id int NOT NULL REFERENCES times,
weight int NOT NULL REFERENCES time_weight_value,
PRIMARY KEY(mentor_id, time_id)
);
CREATE TABLE mentor_theme_pref (
mentor_id INTEGER NOT NULL REFERENCES mentors,
theme_id int NOT NULL REFERENCES themes,
weight int NOT NULL REFERENCES theme_weight_value,
PRIMARY KEY(mentor_id, theme_id)
);
CREATE TABLE mentor_faculty_pref (
mentor_id INTEGER NOT NULL,
faculty_id int NOT NULL,
weight int NOT NULL REFERENCES faculty_weight_value,
PRIMARY KEY (mentor_id, faculty_id)
);
CREATE TABLE themes (
theme_id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
theme_name varchar NOT NULL UNIQUE
);
CREATE TABLE theme_weight_value (
weight INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
value float NOT NULL
);
CREATE TABLE times (
time_id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
time_name varchar NOT NULL UNIQUE,
time_type varchar NOT NULL, -- WEB,HYBRID, or NORMAL
-- days of the week
M bool,
T bool,
W bool,
R bool,
F bool,
time_start int,
time_stop int,
CHECK ( time_type IN (
'WEB', -- web/online only
'HYBRID', -- online and classroom
'NORMAL' -- classroom only
)),
-- If not web-only then days,time_start
-- & time_stop must be set
CHECK (
CASE WHEN time_type != 'WEB' THEN
M IS NOT NULL AND
T IS NOT NULL AND
W IS NOT NULL AND
R IS NOT NULL AND
F IS NOT NULL AND
time_start IS NOT NULL AND
time_stop IS NOT NULL
END
)
);
CREATE TABLE time_weight_value (
weight INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
value float NOT NULL
);
CREATE TABLE departments (
department_id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
department_name varchar NOT NULL UNIQUE
);
CREATE TABLE schedule (
assn_id INTEGER
);