Skip to content
Snippets Groups Projects
TestCreateScript.sql 2.17 KiB
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,
  PRIMARY KEY (uuid)
);
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_11', 'Cloud Speicher', 'Cloud Speicher Description');
INSERT INTO category VALUES ('category/test_id_12', 'Wiki', 'Wiki Description');

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');