Skip to content
Snippets Groups Projects
TestCreateScript.sql 2.58 KiB
Newer Older
DROP SCHEMA provider_toolup;
CREATE SCHEMA provider_toolup;
USE provider_toolup;
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');