Skip to content

Instantly share code, notes, and snippets.

Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save AlexRogalskiy/c127797a8fc351ae67a40334b34bfe4c to your computer and use it in GitHub Desktop.
Save AlexRogalskiy/c127797a8fc351ae67a40334b34bfe4c to your computer and use it in GitHub Desktop.
Create Types and Roles If Not Exist in PostgreSQL
BEGIN;
DO $$
BEGIN
IF NOT EXISTS (SELECT 1 FROM pg_type WHERE typname = 'task_status') THEN
create type task_status AS ENUM ('todo', 'doing', 'blocked', 'done');
END IF;
END
$$;
CREATE TABLE IF NOT EXISTS
tasks (
id integer PRIMARY KEY,
title varchar(200),
status task_status NOT NULL DEFAULT 'todo',
created_date timestamp
);
DO $$
BEGIN
IF NOT EXISTS (SELECT 1 FROM pg_roles WHERE rolname = 'reader') THEN
CREATE ROLE reader;
END IF;
END
$$;
GRANT SELECT ON tasks TO reader;
COMMIT;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment