summaryrefslogtreecommitdiff
path: root/assignments/1/run.sql
blob: 16a57a77756878f56cde6bf10fc38945a84e8389 (plain)
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
DROP TABLE IF EXISTS employees CASCADE;
DROP TABLE IF EXISTS projects CASCADE;
DROP TABLE IF EXISTS departments CASCADE;

CREATE TABLE departments (
  id bigint primary key,
  budget decimal
);

CREATE TABLE projects (
  id bigint primary key,
  department_id bigint references departments(id),
  budget decimal
);

CREATE TABLE employees (
  id bigint primary key,
  department_id bigint references departments(id),
  project_id bigint references projects(id),
  hired_at date,
  title varchar(255),
  phone_number varchar(255) NOT NULL,
  office_number varchar(255) NOT NULL,
  area varchar(255),
  salary decimal,
  manager bit
);

ALTER TABLE employees ADD CONSTRAINT departments_fk FOREIGN KEY (department_id) REFERENCES departments(id);
ALTER TABLE employees ADD CONSTRAINT projects_fk FOREIGN KEY (project_id) REFERENCES projects(id);
ALTER TABLE projects ADD CONSTRAINT departments_fk FOREIGN KEY (department_id) REFERENCES departments(id);
CREATE UNIQUE INDEX managers_idx on employees(department_id, manager) WHERE manager IS NULL;
CREATE UNIQUE INDEX employee_office_idx on employees(office_number);
CREATE UNIQUE INDEX employee_phone_idx on employees(phone_number);

INSERT INTO departments VALUES (1, 1000.00);
INSERT INTO departments VALUES (2, 2000.00);
INSERT INTO departments VALUES (3, 2000.00);

INSERT INTO projects VALUES (1, 1, 500.00);
INSERT INTO projects VALUES (2, 1, 500.00);
INSERT INTO projects VALUES (3, 3, 1000.00);

INSERT INTO employees VALUES(1, 1, 1, '2019-01-01', 'manager', '+1-555-555-5555', '+1-777-777-7777', 'area 51', 50000.00, '1');
INSERT INTO employees VALUES(2, 1, 1, '2019-01-01', 'engineer', '+1-555-555-0001', '+1-777-777-0001', 'area 51', 100000.00, NULL);

-- duplicate phone number
INSERT INTO employees VALUES(3, 1, 1, '2019-01-01', 'manager', '+1-555-555-5555', '+1-888-888-8888', 'area 51', 50002.00, '1');
-- duplicate office number
INSERT INTO employees VALUES(3, 1, 1, '2019-01-01', 'manager', '+1-666-666-6666', '+1-777-777-7777', 'area 51', 50003.00, '1');
-- two managers for the same department
INSERT INTO employees VALUES(3, 1, 1, '2019-01-01', 'manager', '+1-555-555-0002', '+1-777-777-0002', 'area 51', 50000.00, '1');

SELECT * FROM employees;