wisemapping-open-source/config/database/postgres/create-schemas.sql

97 lines
3.3 KiB
MySQL
Raw Normal View History

2013-02-23 19:33:09 +01:00
CREATE TABLE COLLABORATOR (
2013-03-18 03:19:29 +01:00
id SERIAL NOT NULL PRIMARY KEY,
email VARCHAR(255) NOT NULL UNIQUE,
creation_date DATE
2013-02-23 19:33:09 +01:00
);
CREATE TABLE "user" (
2013-03-18 03:19:29 +01:00
authentication_type TEXT NOT NULL,
2013-05-19 16:42:06 +02:00
authenticator_uri VARCHAR(255),
colaborator_id INTEGER NOT NULL PRIMARY KEY,
2013-03-18 03:19:29 +01:00
firstname VARCHAR(255) NOT NULL,
lastname VARCHAR(255) NOT NULL,
password VARCHAR(255) NOT NULL,
activation_code BIGINT NOT NULL,
activation_date DATE,
allow_send_email TEXT NOT NULL DEFAULT 0,
locale VARCHAR(5),
FOREIGN KEY (colaborator_id) REFERENCES COLLABORATOR (id) ON DELETE CASCADE ON UPDATE NO ACTION
);
2013-02-23 19:33:09 +01:00
2014-01-26 03:07:18 +01:00
CREATE TABLE LABEL (
id INTEGER NOT NULL PRIMARY KEY,
title VARCHAR(255),
creator_id INTEGER NOT NULL,
2014-01-28 04:13:29 +01:00
parent_label_id INTEGER,
color VARCHAR(7) NOT NULL
2014-01-26 03:07:18 +01:00
--FOREIGN KEY (creator_id) REFERENCES USER (colaborator_id)
);
CREATE TABLE R_LABEL_MINDMAP (
mindmap_id INTEGER NOT NULL,
label_id INTEGER NOT NULL,
PRIMARY KEY (mindmap_id, label_id),
FOREIGN KEY (mindmap_id) REFERENCES MINDMAP (id),
FOREIGN KEY (label_id) REFERENCES LABEL (id) ON DELETE CASCADE ON UPDATE NO ACTION
2014-01-26 03:07:18 +01:00
);
2013-02-23 19:33:09 +01:00
CREATE TABLE MINDMAP (
2013-03-18 03:19:29 +01:00
id SERIAL NOT NULL PRIMARY KEY,
title VARCHAR(255) NOT NULL,
description VARCHAR(255) NOT NULL,
xml BYTEA NOT NULL,
public BOOL NOT NULL DEFAULT FALSE,
creation_date TIMESTAMP,
edition_date TIMESTAMP,
creator_id INTEGER NOT NULL,
tags VARCHAR(1014),
last_editor_id INTEGER NOT NULL --,
2013-02-23 19:33:09 +01:00
--FOREIGN KEY(creator_id) REFERENCES "USER"(colaborator_id) ON DELETE CASCADE ON UPDATE NO ACTION
2013-03-18 03:19:29 +01:00
);
2013-02-23 19:33:09 +01:00
CREATE TABLE MINDMAP_HISTORY
2013-03-18 03:19:29 +01:00
(id SERIAL NOT NULL PRIMARY KEY,
xml BYTEA NOT NULL,
mindmap_id INTEGER NOT NULL,
creation_date TIMESTAMP,
editor_id INTEGER NOT NULL,
FOREIGN KEY (mindmap_id) REFERENCES MINDMAP (id) ON DELETE CASCADE ON UPDATE NO ACTION
);
2013-02-23 19:33:09 +01:00
2013-03-18 03:19:29 +01:00
CREATE TABLE COLLABORATION_PROPERTIES (
id SERIAL NOT NULL PRIMARY KEY,
starred BOOL NOT NULL DEFAULT FALSE,
mindmap_properties VARCHAR(512)
2013-02-23 19:33:09 +01:00
);
CREATE TABLE COLLABORATION (
2013-03-18 03:19:29 +01:00
id SERIAL NOT NULL PRIMARY KEY,
colaborator_id INTEGER NOT NULL,
properties_id INTEGER NOT NULL,
mindmap_id INTEGER NOT NULL,
role_id INTEGER NOT NULL,
FOREIGN KEY (colaborator_id) REFERENCES COLLABORATOR (id),
FOREIGN KEY (mindmap_id) REFERENCES MINDMAP (id) ON DELETE CASCADE ON UPDATE NO ACTION,
FOREIGN KEY (properties_id) REFERENCES COLLABORATION_PROPERTIES (id) ON DELETE CASCADE ON UPDATE NO ACTION
);
2013-02-23 19:33:09 +01:00
2013-03-18 03:19:29 +01:00
CREATE TABLE TAG (
id SERIAL NOT NULL PRIMARY KEY,
name VARCHAR(255) NOT NULL,
user_id INTEGER NOT NULL --,
2013-02-23 19:33:09 +01:00
--FOREIGN KEY(user_id) REFERENCES "USER"(colaborator_id) ON DELETE CASCADE ON UPDATE NO ACTION
2013-03-18 03:19:29 +01:00
);
2013-02-23 19:33:09 +01:00
CREATE TABLE ACCESS_AUDITORY (
2013-03-18 03:19:29 +01:00
id SERIAL NOT NULL PRIMARY KEY,
login_date DATE,
user_id INTEGER NOT NULL,
FOREIGN KEY (user_id) REFERENCES "user" (colaborator_id) ON DELETE CASCADE ON UPDATE NO ACTION
2013-03-18 03:19:29 +01:00
);
2013-02-23 19:33:09 +01:00
COMMIT;