1 | -- kreiranje.sql
|
---|
2 |
|
---|
3 | -----------------------------
|
---|
4 | -- 1) USER Table
|
---|
5 | -----------------------------
|
---|
6 | CREATE TABLE IF NOT EXISTS "User" (
|
---|
7 | user_id BIGSERIAL PRIMARY KEY,
|
---|
8 | username VARCHAR(50) NOT NULL,
|
---|
9 | email VARCHAR(100) NOT NULL,
|
---|
10 | password_hash VARCHAR(150) NOT NULL,
|
---|
11 | first_name VARCHAR(50),
|
---|
12 | last_name VARCHAR(50)
|
---|
13 | );
|
---|
14 |
|
---|
15 | -----------------------------
|
---|
16 | -- 2) INSTRUCTOR Table
|
---|
17 | -----------------------------
|
---|
18 | CREATE TABLE IF NOT EXISTS "Instructor" (
|
---|
19 | instructor_id BIGSERIAL PRIMARY KEY,
|
---|
20 | first_name VARCHAR(50) NOT NULL,
|
---|
21 | last_name VARCHAR(50) NOT NULL,
|
---|
22 | biography TEXT
|
---|
23 | );
|
---|
24 |
|
---|
25 | -----------------------------
|
---|
26 | -- 3) TRAINING Table
|
---|
27 | -----------------------------
|
---|
28 | CREATE TABLE IF NOT EXISTS "Training" (
|
---|
29 | training_id BIGSERIAL PRIMARY KEY,
|
---|
30 | training_name VARCHAR(100) NOT NULL,
|
---|
31 | description TEXT,
|
---|
32 | duration INT,
|
---|
33 | intensity_level VARCHAR(50)
|
---|
34 | );
|
---|
35 |
|
---|
36 | -----------------------------
|
---|
37 | -- 4) CLASS Table
|
---|
38 | -----------------------------
|
---|
39 | CREATE TABLE IF NOT EXISTS "Class" (
|
---|
40 | class_id BIGSERIAL PRIMARY KEY,
|
---|
41 | date DATE NOT NULL,
|
---|
42 | start_time TIME NOT NULL,
|
---|
43 | end_time TIME NOT NULL,
|
---|
44 | location VARCHAR(100) NOT NULL,
|
---|
45 | capacity INT,
|
---|
46 | seats_available INT,
|
---|
47 | instructor_id BIGINT,
|
---|
48 | CONSTRAINT fk_instructor
|
---|
49 | FOREIGN KEY (instructor_id)
|
---|
50 | REFERENCES "Instructor"(instructor_id)
|
---|
51 | ON DELETE SET NULL
|
---|
52 | );
|
---|
53 |
|
---|
54 | -----------------------------
|
---|
55 | -- 5) EVENT Table
|
---|
56 | -----------------------------
|
---|
57 | CREATE TABLE IF NOT EXISTS "Event" (
|
---|
58 | event_id BIGSERIAL PRIMARY KEY,
|
---|
59 | event_name VARCHAR(100) NOT NULL,
|
---|
60 | description TEXT,
|
---|
61 | date DATE NOT NULL,
|
---|
62 | time TIME NOT NULL,
|
---|
63 | location VARCHAR(100) NOT NULL
|
---|
64 | );
|
---|
65 |
|
---|
66 | -----------------------------
|
---|
67 | -- 6) PACKAGE Table
|
---|
68 | -----------------------------
|
---|
69 | CREATE TABLE IF NOT EXISTS "Package" (
|
---|
70 | package_id BIGSERIAL PRIMARY KEY,
|
---|
71 | package_name VARCHAR(100) NOT NULL,
|
---|
72 | price DECIMAL(10,2) NOT NULL,
|
---|
73 | num_classes INT NOT NULL
|
---|
74 | );
|
---|
75 |
|
---|
76 | -----------------------------
|
---|
77 | -- 7) MERCH_ITEMS Table
|
---|
78 | -----------------------------
|
---|
79 | CREATE TABLE IF NOT EXISTS "Merch_Items" (
|
---|
80 | merch_id BIGSERIAL PRIMARY KEY,
|
---|
81 | item_name VARCHAR(100) NOT NULL,
|
---|
82 | description TEXT,
|
---|
83 | price DECIMAL(10,2) NOT NULL,
|
---|
84 | quantity_in_stock INT
|
---|
85 | );
|
---|
86 |
|
---|
87 | ----------------------------------------------------
|
---|
88 | -- M:N Bridge Tables
|
---|
89 | ----------------------------------------------------
|
---|
90 |
|
---|
91 | -- 1) USER_CLASS (books)
|
---|
92 | CREATE TABLE IF NOT EXISTS "User_Class" (
|
---|
93 | user_id BIGINT,
|
---|
94 | class_id BIGINT,
|
---|
95 | PRIMARY KEY(user_id, class_id),
|
---|
96 | FOREIGN KEY (user_id) REFERENCES "User"(user_id) ON DELETE CASCADE,
|
---|
97 | FOREIGN KEY (class_id) REFERENCES "Class"(class_id) ON DELETE CASCADE
|
---|
98 | );
|
---|
99 |
|
---|
100 | -- 2) CLASS_TRAINING (is_scheduled_for)
|
---|
101 | CREATE TABLE IF NOT EXISTS "Class_Training" (
|
---|
102 | class_id BIGINT,
|
---|
103 | training_id BIGINT,
|
---|
104 | PRIMARY KEY(class_id, training_id),
|
---|
105 | FOREIGN KEY (class_id) REFERENCES "Class"(class_id) ON DELETE CASCADE,
|
---|
106 | FOREIGN KEY (training_id) REFERENCES "Training"(training_id) ON DELETE CASCADE
|
---|
107 | );
|
---|
108 |
|
---|
109 | -- 3) USER_EVENT (registers)
|
---|
110 | CREATE TABLE IF NOT EXISTS "User_Event" (
|
---|
111 | user_id BIGINT,
|
---|
112 | event_id BIGINT,
|
---|
113 | PRIMARY KEY(user_id, event_id),
|
---|
114 | FOREIGN KEY (user_id) REFERENCES "User"(user_id) ON DELETE CASCADE,
|
---|
115 | FOREIGN KEY (event_id) REFERENCES "Event"(event_id) ON DELETE CASCADE
|
---|
116 | );
|
---|
117 |
|
---|
118 | -- 4) USER_PACKAGE (buys)
|
---|
119 | CREATE TABLE IF NOT EXISTS "User_Package" (
|
---|
120 | user_id BIGINT,
|
---|
121 | package_id BIGINT,
|
---|
122 | PRIMARY KEY(user_id, package_id),
|
---|
123 | FOREIGN KEY (user_id) REFERENCES "User"(user_id) ON DELETE CASCADE,
|
---|
124 | FOREIGN KEY (package_id) REFERENCES "Package"(package_id) ON DELETE CASCADE
|
---|
125 | );
|
---|
126 |
|
---|
127 | -- 5) USER_MERCH (purchases)
|
---|
128 | CREATE TABLE IF NOT EXISTS "User_Merch" (
|
---|
129 | user_id BIGINT,
|
---|
130 | merch_id BIGINT,
|
---|
131 | PRIMARY KEY(user_id, merch_id),
|
---|
132 | FOREIGN KEY (user_id) REFERENCES "User"(user_id) ON DELETE CASCADE,
|
---|
133 | FOREIGN KEY (merch_id) REFERENCES "Merch_Items"(merch_id) ON DELETE CASCADE
|
---|
134 | );
|
---|
135 |
|
---|
136 | -- 6) PACKAGE_CLASS (is_for)
|
---|
137 | CREATE TABLE IF NOT EXISTS "Package_Class" (
|
---|
138 | package_id BIGINT,
|
---|
139 | class_id BIGINT,
|
---|
140 | PRIMARY KEY(package_id, class_id),
|
---|
141 | FOREIGN KEY (package_id) REFERENCES "Package"(package_id) ON DELETE CASCADE,
|
---|
142 | FOREIGN KEY (class_id) REFERENCES "Class"(class_id) ON DELETE CASCADE
|
---|
143 | );
|
---|
144 |
|
---|
145 | ----------------------------------------------------
|
---|
146 | -- Optional: Drop (comment out unless needed)
|
---|
147 | ----------------------------------------------------
|
---|
148 | -- DROP TABLE IF EXISTS "Package_Class" CASCADE;
|
---|
149 | -- DROP TABLE IF EXISTS "User_Merch" CASCADE;
|
---|
150 | -- DROP TABLE IF EXISTS "User_Class" CASCADE;
|
---|
151 | -- ...
|
---|
152 | -- DROP TABLE IF EXISTS "User" CASCADE;
|
---|
153 |
|
---|
154 | -- End of kreiranje.sql
|
---|