| 1 | -- create.sql (BlissCore)
|
|---|
| 2 |
|
|---|
| 3 | -- RESET (optional):
|
|---|
| 4 |
|
|---|
| 5 | /*
|
|---|
| 6 | -- Drop NEW bridge tables (if they exist)
|
|---|
| 7 | DROP TABLE IF EXISTS "User_Booked_Class" CASCADE;
|
|---|
| 8 | DROP TABLE IF EXISTS "Class_Includes_Training" CASCADE;
|
|---|
| 9 | DROP TABLE IF EXISTS "User_Purchased_Package" CASCADE;
|
|---|
| 10 | DROP TABLE IF EXISTS "User_Purchased_Merch" CASCADE;
|
|---|
| 11 | DROP TABLE IF EXISTS "Package_Includes_Class" CASCADE;
|
|---|
| 12 |
|
|---|
| 13 | -- Drop OLD bridge tables (from previous versions) just in case
|
|---|
| 14 | DROP TABLE IF EXISTS "User_Class" CASCADE;
|
|---|
| 15 | DROP TABLE IF EXISTS "Class_Training" CASCADE;
|
|---|
| 16 | DROP TABLE IF EXISTS "User_Package" CASCADE;
|
|---|
| 17 | DROP TABLE IF EXISTS "User_Merch" CASCADE;
|
|---|
| 18 | DROP TABLE IF EXISTS "Package_Class" CASCADE;
|
|---|
| 19 |
|
|---|
| 20 | -- Keep this one (backend uses it), but drop if you want a full reset:
|
|---|
| 21 | -- DROP TABLE IF EXISTS "User_Event" CASCADE;
|
|---|
| 22 |
|
|---|
| 23 | -- Drop base tables (order matters due to FKs)
|
|---|
| 24 | DROP TABLE IF EXISTS "Merch_Items" CASCADE;
|
|---|
| 25 | DROP TABLE IF EXISTS "Package" CASCADE;
|
|---|
| 26 | DROP TABLE IF EXISTS "Event" CASCADE;
|
|---|
| 27 | DROP TABLE IF EXISTS "Class" CASCADE;
|
|---|
| 28 | DROP TABLE IF EXISTS "Training" CASCADE;
|
|---|
| 29 | DROP TABLE IF EXISTS "Instructor" CASCADE;
|
|---|
| 30 | DROP TABLE IF EXISTS "User" CASCADE;
|
|---|
| 31 | */
|
|---|
| 32 |
|
|---|
| 33 |
|
|---|
| 34 | -- CREATE TABLES
|
|---|
| 35 |
|
|---|
| 36 | CREATE TABLE IF NOT EXISTS "User" (
|
|---|
| 37 | user_id BIGSERIAL PRIMARY KEY,
|
|---|
| 38 | username VARCHAR(50) NOT NULL,
|
|---|
| 39 | email VARCHAR(100) NOT NULL,
|
|---|
| 40 | password_hash VARCHAR(150) NOT NULL,
|
|---|
| 41 | first_name VARCHAR(50),
|
|---|
| 42 | last_name VARCHAR(50)
|
|---|
| 43 | );
|
|---|
| 44 |
|
|---|
| 45 |
|
|---|
| 46 | CREATE TABLE IF NOT EXISTS "Instructor" (
|
|---|
| 47 | instructor_id BIGSERIAL PRIMARY KEY,
|
|---|
| 48 | instructor_email VARCHAR(100) NOT NULL,
|
|---|
| 49 | instructor_password_hash VARCHAR(150) NOT NULL,
|
|---|
| 50 | first_name VARCHAR(50) NOT NULL,
|
|---|
| 51 | last_name VARCHAR(50) NOT NULL,
|
|---|
| 52 | biography TEXT
|
|---|
| 53 | );
|
|---|
| 54 |
|
|---|
| 55 |
|
|---|
| 56 | CREATE TABLE IF NOT EXISTS "Training" (
|
|---|
| 57 | training_id BIGSERIAL PRIMARY KEY,
|
|---|
| 58 | training_name VARCHAR(100) NOT NULL,
|
|---|
| 59 | description TEXT,
|
|---|
| 60 | duration INT,
|
|---|
| 61 | intensity_level VARCHAR(50)
|
|---|
| 62 | );
|
|---|
| 63 |
|
|---|
| 64 |
|
|---|
| 65 | CREATE TABLE IF NOT EXISTS "Class" (
|
|---|
| 66 | class_id BIGSERIAL PRIMARY KEY,
|
|---|
| 67 | date DATE NOT NULL,
|
|---|
| 68 | start_time TIME NOT NULL,
|
|---|
| 69 | end_time TIME NOT NULL,
|
|---|
| 70 | location VARCHAR(100) NOT NULL,
|
|---|
| 71 | capacity INT,
|
|---|
| 72 | seats_available INT,
|
|---|
| 73 | instructor_id BIGINT,
|
|---|
| 74 | CONSTRAINT fk_instructor
|
|---|
| 75 | FOREIGN KEY (instructor_id)
|
|---|
| 76 | REFERENCES "Instructor"(instructor_id)
|
|---|
| 77 | ON DELETE SET NULL
|
|---|
| 78 | );
|
|---|
| 79 |
|
|---|
| 80 |
|
|---|
| 81 | CREATE TABLE IF NOT EXISTS "Event" (
|
|---|
| 82 | event_id BIGSERIAL PRIMARY KEY,
|
|---|
| 83 | event_name VARCHAR(100) NOT NULL,
|
|---|
| 84 | description TEXT,
|
|---|
| 85 | date DATE NOT NULL,
|
|---|
| 86 | time TIME NOT NULL,
|
|---|
| 87 | location VARCHAR(100) NOT NULL
|
|---|
| 88 | );
|
|---|
| 89 |
|
|---|
| 90 |
|
|---|
| 91 | CREATE TABLE IF NOT EXISTS "Package" (
|
|---|
| 92 | package_id BIGSERIAL PRIMARY KEY,
|
|---|
| 93 | package_name VARCHAR(100) NOT NULL,
|
|---|
| 94 | price DECIMAL(10,2) NOT NULL,
|
|---|
| 95 | num_classes INT NOT NULL
|
|---|
| 96 | );
|
|---|
| 97 |
|
|---|
| 98 |
|
|---|
| 99 | CREATE TABLE IF NOT EXISTS "Merch_Items" (
|
|---|
| 100 | merch_id BIGSERIAL PRIMARY KEY,
|
|---|
| 101 | item_name VARCHAR(100) NOT NULL,
|
|---|
| 102 | description TEXT,
|
|---|
| 103 | price DECIMAL(10,2) NOT NULL,
|
|---|
| 104 | quantity_in_stock INT
|
|---|
| 105 | );
|
|---|
| 106 |
|
|---|
| 107 | -- M:N BRIDGE TABLES (new names)
|
|---|
| 108 | ----------------------------------------------------
|
|---|
| 109 |
|
|---|
| 110 | -- (1) User books a Class
|
|---|
| 111 | CREATE TABLE IF NOT EXISTS "User_Booked_Class" (
|
|---|
| 112 | user_id BIGINT,
|
|---|
| 113 | class_id BIGINT,
|
|---|
| 114 | PRIMARY KEY(user_id, class_id),
|
|---|
| 115 | FOREIGN KEY (user_id) REFERENCES "User"(user_id) ON DELETE CASCADE,
|
|---|
| 116 | FOREIGN KEY (class_id) REFERENCES "Class"(class_id) ON DELETE CASCADE
|
|---|
| 117 | );
|
|---|
| 118 |
|
|---|
| 119 | -- (2) A Class includes one or more Trainings
|
|---|
| 120 | CREATE TABLE IF NOT EXISTS "Class_Includes_Training" (
|
|---|
| 121 | class_id BIGINT,
|
|---|
| 122 | training_id BIGINT,
|
|---|
| 123 | PRIMARY KEY(class_id, training_id),
|
|---|
| 124 | FOREIGN KEY (class_id) REFERENCES "Class"(class_id) ON DELETE CASCADE,
|
|---|
| 125 | FOREIGN KEY (training_id) REFERENCES "Training"(training_id) ON DELETE CASCADE
|
|---|
| 126 | );
|
|---|
| 127 |
|
|---|
| 128 | -- (3) User registers for an Event
|
|---|
| 129 | CREATE TABLE IF NOT EXISTS "User_Event" (
|
|---|
| 130 | user_id BIGINT,
|
|---|
| 131 | event_id BIGINT,
|
|---|
| 132 | PRIMARY KEY(user_id, event_id),
|
|---|
| 133 | FOREIGN KEY (user_id) REFERENCES "User"(user_id) ON DELETE CASCADE,
|
|---|
| 134 | FOREIGN KEY (event_id) REFERENCES "Event"(event_id) ON DELETE CASCADE
|
|---|
| 135 | );
|
|---|
| 136 |
|
|---|
| 137 | -- (4) User purchases a Package
|
|---|
| 138 | CREATE TABLE IF NOT EXISTS "User_Purchased_Package" (
|
|---|
| 139 | user_id BIGINT,
|
|---|
| 140 | package_id BIGINT,
|
|---|
| 141 | PRIMARY KEY(user_id, package_id),
|
|---|
| 142 | FOREIGN KEY (user_id) REFERENCES "User"(user_id) ON DELETE CASCADE,
|
|---|
| 143 | FOREIGN KEY (package_id) REFERENCES "Package"(package_id) ON DELETE CASCADE
|
|---|
| 144 | );
|
|---|
| 145 |
|
|---|
| 146 | -- (5) User purchases Merch
|
|---|
| 147 | CREATE TABLE IF NOT EXISTS "User_Purchased_Merch" (
|
|---|
| 148 | user_id BIGINT,
|
|---|
| 149 | merch_id BIGINT,
|
|---|
| 150 | PRIMARY KEY(user_id, merch_id),
|
|---|
| 151 | FOREIGN KEY (user_id) REFERENCES "User"(user_id) ON DELETE CASCADE,
|
|---|
| 152 | FOREIGN KEY (merch_id) REFERENCES "Merch_Items"(merch_id) ON DELETE CASCADE
|
|---|
| 153 | );
|
|---|
| 154 |
|
|---|
| 155 | -- (6) Package includes specific Classes
|
|---|
| 156 | CREATE TABLE IF NOT EXISTS "Package_Includes_Class" (
|
|---|
| 157 | package_id BIGINT,
|
|---|
| 158 | class_id BIGINT,
|
|---|
| 159 | PRIMARY KEY(package_id, class_id),
|
|---|
| 160 | FOREIGN KEY (package_id) REFERENCES "Package"(package_id) ON DELETE CASCADE,
|
|---|
| 161 | FOREIGN KEY (class_id) REFERENCES "Class"(class_id) ON DELETE CASCADE
|
|---|
| 162 | );
|
|---|