summaryrefslogblamecommitdiffstats
path: root/data_model/schema.sql
blob: c4a554da0459f9bfff16c049191c793ad507386f (plain) (tree)





















































                                                                                                   
BEGIN TRANSACTION;
DROP TABLE IF EXISTS "Schedules";
CREATE TABLE IF NOT EXISTS "Schedules" (
	"id"	INTEGER,
	"name"	TEXT NOT NULL,
	PRIMARY KEY("id")
);
DROP TABLE IF EXISTS "Tasks";
CREATE TABLE IF NOT EXISTS "Tasks" (
	"id"	INTEGER,
	"name"	TEXT NOT NULL,
	"description"	TEXT,
	"frequency"	INTEGER NOT NULL,
	"estimated_length"	INTEGER,
	"date_completed"	INTEGER,
	PRIMARY KEY("id")
);
DROP TABLE IF EXISTS "TimeSlotTasks";
CREATE TABLE IF NOT EXISTS "TimeSlotTasks" (
	"timeslot_id"	INTEGER NOT NULL,
	"task_id"	INTEGER NOT NULL,
	PRIMARY KEY("timeslot_id","task_id"),
	FOREIGN KEY("task_id") REFERENCES "Tasks"("id") ON UPDATE CASCADE ON DELETE CASCADE,
	FOREIGN KEY("timeslot_id") REFERENCES "TimeSlots"("id") ON UPDATE CASCADE ON DELETE CASCADE
);
DROP TABLE IF EXISTS "SubTasks";
CREATE TABLE IF NOT EXISTS "SubTasks" (
	"id"	INTEGER,
	"task_id"	INTEGER NOT NULL,
	"name"	TEXT NOT NULL,
	"date_completed"	INTEGER,
	PRIMARY KEY("id"),
	FOREIGN KEY("task_id") REFERENCES "Tasks"("id") ON UPDATE CASCADE ON DELETE CASCADE
);
DROP TABLE IF EXISTS "TimeSlots";
CREATE TABLE IF NOT EXISTS "TimeSlots" (
	"id"	INTEGER,
	"schedule_id"	INTEGER NOT NULL,
	"start_time"	INTEGER NOT NULL,
	"end_time"	INTEGER NOT NULL,
	"name"	TEXT NOT NULL,
	"date_completed"	INTEGER,
	PRIMARY KEY("id"),
	FOREIGN KEY("schedule_id") REFERENCES "Schedules"("id") ON UPDATE CASCADE ON DELETE CASCADE
);
DROP TABLE IF EXISTS "Version";
CREATE TABLE IF NOT EXISTS "Version" (
	"major"	INTEGER NOT NULL,
	"minor"	INTEGER NOT NULL,
	"patch"	INTEGER NOT NULL
);
INSERT INTO "Schedules" VALUES (1,'default');
INSERT INTO "Version" VALUES (0,1,0);
COMMIT;