Newer
Older
DROP SCHEMA test;
CREATE SCHEMA test;
USE test;
CREATE TABLE application (
uuid VARCHAR(64) NOT NULL,
title VARCHAR(128) NOT NULL,
description LONGTEXT,
PRIMARY KEY (uuid)
);
CREATE TABLE category (
uuid VARCHAR(64) NOT NULL,
title VARCHAR(128) NOT NULL,
description LONGTEXT,
supercategory VARCHAR(64),
PRIMARY KEY (uuid),
FOREIGN KEY (supercategory) REFERENCES category (uuid)
ON DELETE SET NULL
);
CREATE TABLE feature (
uuid VARCHAR(64) NOT NULL,
title VARCHAR(128) NOT NULL,
description LONGTEXT,
PRIMARY KEY (uuid)
);
CREATE TABLE application_belongs_to_category (
application_uuid VARCHAR(64) NOT NULL,
category_uuid VARCHAR(64) NOT NULL,
PRIMARY KEY (application_uuid, category_uuid),
FOREIGN KEY (application_uuid) REFERENCES application (uuid)
ON DELETE CASCADE,
FOREIGN KEY (category_uuid) REFERENCES category (uuid)
ON DELETE CASCADE
);
CREATE TABLE application_has_feature (
application_uuid VARCHAR(64) NOT NULL,
feature_uuid VARCHAR(64) NOT NULL,
PRIMARY KEY (application_uuid, feature_uuid),
FOREIGN KEY (application_uuid) REFERENCES application (uuid)
ON DELETE CASCADE,
FOREIGN KEY (feature_uuid) REFERENCES feature (uuid)
ON DELETE CASCADE
);
INSERT INTO application VALUES ('application-test_id_1', 'Dropbox', 'Dropbox Description');
INSERT INTO application VALUES ('application-test_id_2', 'Box.UP', 'Box.UP Description');
INSERT INTO category
VALUES ('category-test_id_13', 'Überkategorie', 'Eine Kategorie zum Testen der Superkategorie-Beziehung', NULL);
INSERT INTO category
VALUES ('category-test_id_11', 'Cloud Speicher', 'Cloud Speicher Description', 'category-test_id_13');
INSERT INTO category VALUES ('category-test_id_12', 'Wiki', 'Wiki Description', 'category-test_id_13');
INSERT INTO feature VALUES ('feature-test_id_21', 'Kalender anlegen', 'Kalender anlegen Description');
INSERT INTO feature VALUES ('feature-test_id_22', 'Termine teilen', 'Termine teilen Description');
INSERT INTO application_belongs_to_category VALUES ('application-test_id_1', 'category-test_id_11');
INSERT INTO application_belongs_to_category VALUES ('application-test_id_2', 'category-test_id_11');
INSERT INTO application_has_feature VALUES ('application-test_id_1', 'feature-test_id_21');
INSERT INTO application_has_feature VALUES ('application-test_id_1', 'feature-test_id_22');
INSERT INTO application_has_feature VALUES ('application-test_id_2', 'feature-test_id_21');