diff options
author | Yulqen <246857+yulqen@users.noreply.github.com> | 2024-04-18 13:58:11 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-04-18 13:58:11 +0100 |
commit | 69017cc225e2754466b8444ca42cb1122208425d (patch) | |
tree | 6a7ac8d150b95c1fad9229d124a23737abc17964 /postgresql | |
parent | 530f08071fc1295fabdaedf9724b8cda48780927 (diff) | |
parent | f08ac7b887e0bae0cb67362eec90a575faec07f1 (diff) |
Merge pull request #4 from defencedigital/changes
Changes
Diffstat (limited to 'postgresql')
-rw-r--r-- | postgresql/Dockerfile | 2 | ||||
-rw-r--r-- | postgresql/populate.sql | 82 |
2 files changed, 84 insertions, 0 deletions
diff --git a/postgresql/Dockerfile b/postgresql/Dockerfile new file mode 100644 index 0000000..efe7c5f --- /dev/null +++ b/postgresql/Dockerfile @@ -0,0 +1,2 @@ +FROM postgres:16-alpine +COPY postgresql/populate.sql /docker-entrypoint-initdb.d/ diff --git a/postgresql/populate.sql b/postgresql/populate.sql new file mode 100644 index 0000000..7fa09f4 --- /dev/null +++ b/postgresql/populate.sql @@ -0,0 +1,82 @@ +CREATE DATABASE ded; + +-- Install uuid-ossp extension +CREATE EXTENSION IF NOT EXISTS "uuid-ossp"; + +-- Create the Organisations table. +CREATE TABLE organisations ( + id SERIAL PRIMARY KEY, + name VARCHAR(100) NOT NULL, + created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP +); + +-- Add index to created column. +CREATE INDEX idx_organisations_created ON organisations(created); + +-- Let's add some placeholder data to organisations table. +INSERT INTO organisations (name, created) VALUES ('Random Organisation 1', CURRENT_TIMESTAMP); +INSERT INTO organisations (name, created) VALUES ('Random Organisation 2', CURRENT_TIMESTAMP); +INSERT INTO organisations (name, created) VALUES ('Random Organisation 3', CURRENT_TIMESTAMP); + +-- Persons! +CREATE TABLE persons ( + id UUID PRIMARY KEY DEFAULT uuid_generate_v4(), + first_name VARCHAR(56) NOT NULL, + last_name VARCHAR(56) NOT NULL, + organisation_id INT NOT NULL, + role_name VARCHAR(56) NOT NULL, + created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, + CONSTRAINT fk_person_organisation + FOREIGN KEY(organisation_id) + REFERENCES organisations(id) + ON DELETE CASCADE +); + +-- Add index to created column. +CREATE INDEX idx_persons_created ON persons(created); + +-- Add some people +INSERT INTO persons (first_name, last_name, organisation_id, role_name, created) VALUES ('Larry', 'Cluno', 1, 'Lead Inspector', CURRENT_TIMESTAMP); +INSERT INTO persons (first_name, last_name, organisation_id, role_name, created) VALUES ('Olivia', 'Capstan-Melville', 1, 'Lead Inspector', CURRENT_TIMESTAMP); + +-- Operations! +CREATE TABLE operations ( + id SERIAL PRIMARY KEY, + name VARCHAR(100) NOT NULL, + description VARCHAR(255) NOT NULL, + organisation_id INT NOT NULL, + created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, + CONSTRAINT fk_operation_organisation + FOREIGN KEY(organisation_id) + REFERENCES organisations(id) + ON DELETE CASCADE +); + +-- Add index to created column. +CREATE INDEX idx_operations_created ON operations(created); + +-- Engagement Strategies +CREATE TABLE engagement_strategies ( + id SERIAL PRIMARY KEY, + valid_from TIMESTAMP NOT NULL, + valid_to TIMESTAMP NOT NULL, + description VARCHAR(255), + operation_id INT NOT NULL, + created TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, + CONSTRAINT fk_es_operation + FOREIGN KEY(operation_id) + REFERENCES operations(id) + ON DELETE CASCADE +); + +CREATE INDEX idx_engagement_strategy_created ON engagement_strategies(created); + +-- Create some operations +INSERT INTO operations (name, created, description, organisation_id) VALUES ('Operation 1', CURRENT_TIMESTAMP, 'Operation 1 Description', 1); +INSERT INTO operations (name, created, description, organisation_id) VALUES ('Operation 2', CURRENT_TIMESTAMP, 'Operation 2 Description', 1); +INSERT INTO operations (name, created, description, organisation_id) VALUES ('Operation 3', CURRENT_TIMESTAMP, 'Operation 3 Description', 2); + +-- Create some ESs +INSERT INTO engagement_strategies (valid_from, valid_to, operation_id, created) VALUES ('2021-01-01', '2023-01-01', 1, CURRENT_TIMESTAMP); +INSERT INTO engagement_strategies (valid_from, valid_to, operation_id, created) VALUES ('2023-01-01', '2025-01-01', 1, CURRENT_TIMESTAMP); + |