| 1 | drop table if exists workers cascade;
|
|---|
| 2 | drop table if exists customers cascade;
|
|---|
| 3 | drop table if exists salaries cascade;
|
|---|
| 4 | drop table if exists films cascade;
|
|---|
| 5 | drop table if exists events cascade;
|
|---|
| 6 | drop table if exists users cascade;
|
|---|
| 7 | drop table if exists cinemas cascade;
|
|---|
| 8 | drop table if exists categories cascade;
|
|---|
| 9 | drop table if exists discounts cascade;
|
|---|
| 10 | drop table if exists seats cascade;
|
|---|
| 11 | drop table if exists projections cascade;
|
|---|
| 12 | drop table if exists projection_rooms cascade;
|
|---|
| 13 | drop table if exists tickets cascade;
|
|---|
| 14 | drop table if exists customer_rates_film cascade;
|
|---|
| 15 | drop table if exists cinema_plays_film cascade;
|
|---|
| 16 | drop table if exists cinema_organizes_event cascade;
|
|---|
| 17 | drop table if exists projection_is_played_in_room cascade;
|
|---|
| 18 | drop table if exists customer_is_interested_in_event cascade;
|
|---|
| 19 | drop table if exists work_hours_weekly cascade;
|
|---|
| 20 | drop schema if exists project cascade;
|
|---|
| 21 |
|
|---|
| 22 | create schema project;
|
|---|
| 23 |
|
|---|
| 24 |
|
|---|
| 25 | create table users(
|
|---|
| 26 | ID_user serial primary key,
|
|---|
| 27 | password varchar(200) not NULL,
|
|---|
| 28 | first_name varchar(200) not null,
|
|---|
| 29 | last_name varchar(200) not null,
|
|---|
| 30 | address varchar(20000) not null,
|
|---|
| 31 | contact_number varchar(20000) not null,
|
|---|
| 32 | date_created date not null
|
|---|
| 33 | );
|
|---|
| 34 | create table cinemas(
|
|---|
| 35 | ID_cinema serial primary key,
|
|---|
| 36 | name varchar(200) not null,
|
|---|
| 37 | location varchar(200) not null
|
|---|
| 38 | );
|
|---|
| 39 | create table workers(
|
|---|
| 40 | ID_worker serial primary key references users(ID_user),
|
|---|
| 41 | position varchar(200) not NULL,
|
|---|
| 42 | work_hours_from varchar(200) not null,
|
|---|
| 43 | work_hours_to varchar(200) not null,
|
|---|
| 44 | ID_cinema integer references cinemas(ID_cinema) not null
|
|---|
| 45 | );
|
|---|
| 46 |
|
|---|
| 47 | create table customers(
|
|---|
| 48 | ID_customer serial primary key references users(ID_User),
|
|---|
| 49 | points integer
|
|---|
| 50 | );
|
|---|
| 51 |
|
|---|
| 52 | create table salaries(
|
|---|
| 53 | ID_salary serial primary key,
|
|---|
| 54 | sum integer not null,
|
|---|
| 55 | date_from date not null,
|
|---|
| 56 | date_to date,
|
|---|
| 57 | ID_worker integer references workers(ID_worker) not null
|
|---|
| 58 | );
|
|---|
| 59 | create table films(
|
|---|
| 60 | ID_film serial primary key,
|
|---|
| 61 | name varchar(200) not null,
|
|---|
| 62 | duration integer not null,
|
|---|
| 63 | actors varchar(20000) not null,
|
|---|
| 64 | genre varchar(2000) not null,
|
|---|
| 65 | age_category varchar(2000) not null,
|
|---|
| 66 | director varchar(2000) not null,
|
|---|
| 67 | description varchar(20000),
|
|---|
| 68 | start_date date not null,
|
|---|
| 69 | end_date date not null
|
|---|
| 70 | );
|
|---|
| 71 | create table events(
|
|---|
| 72 | ID_event serial primary key,
|
|---|
| 73 | theme varchar(2000),
|
|---|
| 74 | duration varchar(2000) not null,
|
|---|
| 75 | repeating varchar(200),
|
|---|
| 76 | start_date date not null
|
|---|
| 77 | );
|
|---|
| 78 | create table discounts(
|
|---|
| 79 | ID_discount serial primary key,
|
|---|
| 80 | validity date not null,
|
|---|
| 81 | code varchar(2000) not null,
|
|---|
| 82 | type varchar(2000),
|
|---|
| 83 | percent integer not null
|
|---|
| 84 | );
|
|---|
| 85 |
|
|---|
| 86 | create table projections(
|
|---|
| 87 | ID_projection serial primary key,
|
|---|
| 88 | date_time_start date not null,
|
|---|
| 89 | type_of_technology varchar(200) not null,
|
|---|
| 90 | date_time_end date not null,
|
|---|
| 91 | ID_film integer references films(ID_film) not null,
|
|---|
| 92 | ID_discount integer references discounts(ID_discount),
|
|---|
| 93 | ID_event integer references events(ID_event)
|
|---|
| 94 | );
|
|---|
| 95 | create table projection_rooms(
|
|---|
| 96 | ID_room serial primary key,
|
|---|
| 97 | number_of_seats integer not null,
|
|---|
| 98 | projection_room_number integer not null,
|
|---|
| 99 | ID_cinema integer references cinemas(ID_cinema) not null
|
|---|
| 100 | );
|
|---|
| 101 | create table categories(
|
|---|
| 102 | ID_category serial primary key,
|
|---|
| 103 | name varchar(2000) not null,
|
|---|
| 104 | extra_amount integer
|
|---|
| 105 | );
|
|---|
| 106 |
|
|---|
| 107 | create table seats(
|
|---|
| 108 | ID_seat serial primary key,
|
|---|
| 109 | seat_number integer not null,
|
|---|
| 110 | ID_room integer references projection_rooms(ID_room) not null,
|
|---|
| 111 | ID_category integer references categories(ID_category)
|
|---|
| 112 | );
|
|---|
| 113 | create table tickets(
|
|---|
| 114 | ID_ticket serial primary key,
|
|---|
| 115 | price bigint not null,
|
|---|
| 116 | ID_customer integer references customers(ID_customer) not null,
|
|---|
| 117 | date_reserved date not null,
|
|---|
| 118 | ID_projection integer references projections(ID_projection) not null,
|
|---|
| 119 | ID_discount integer references discounts(ID_discount),
|
|---|
| 120 | ID_seat integer references seats(ID_seat) not null
|
|---|
| 121 | );
|
|---|
| 122 |
|
|---|
| 123 | create table customer_rates_film(
|
|---|
| 124 | ID_customer integer references customers(ID_customer) not null,
|
|---|
| 125 | ID_film integer references films(ID_film) not null,
|
|---|
| 126 | rating float not null,
|
|---|
| 127 | CONSTRAINT pk_customer_film PRIMARY KEY (ID_customer, ID_film)
|
|---|
| 128 | );
|
|---|
| 129 |
|
|---|
| 130 | create table cinema_plays_film(
|
|---|
| 131 | ID_cinema integer references cinemas(ID_cinema),
|
|---|
| 132 | ID_film integer references films(ID_film),
|
|---|
| 133 | CONSTRAINT pk_cinema_film PRIMARY KEY (ID_cinema, ID_film)
|
|---|
| 134 | );
|
|---|
| 135 |
|
|---|
| 136 | create table cinema_organizes_event(
|
|---|
| 137 | ID_cinema integer references cinemas(ID_cinema),
|
|---|
| 138 | ID_event integer references events(ID_event),
|
|---|
| 139 | CONSTRAINT pk_cinema_event PRIMARY KEY (ID_cinema,ID_event)
|
|---|
| 140 | );
|
|---|
| 141 |
|
|---|
| 142 | create table projection_is_played_in_room(
|
|---|
| 143 | ID_projection integer references projections(ID_projection),
|
|---|
| 144 | ID_room integer references projection_rooms(ID_room),
|
|---|
| 145 | CONSTRAINT pk_projection_room PRIMARY KEY (ID_projection,ID_room)
|
|---|
| 146 | );
|
|---|
| 147 | create table customer_is_interested_in_event(
|
|---|
| 148 | id_customer integer references customers(ID_customer),
|
|---|
| 149 | id_event integer references events(id_event),
|
|---|
| 150 | constraint ce_customer_event PRIMARY KEY (id_customer,id_event)
|
|---|
| 151 | );
|
|---|
| 152 | create table work_hours_weekly(
|
|---|
| 153 | id_work_hours serial primary key,
|
|---|
| 154 | id_worker integer references workers(id_worker) not null,
|
|---|
| 155 | week_number integer not null,
|
|---|
| 156 | year_num varchar(200) not null,
|
|---|
| 157 | hours_from timestamp not null,
|
|---|
| 158 | hours_to timestamp not null,
|
|---|
| 159 | check_in bool
|
|---|
| 160 | ); |
|---|