Skip to content

GitLab

  • Menu
Projects Groups Snippets
    • Loading...
  • Help
    • Help
    • Support
    • Community forum
    • Submit feedback
    • Contribute to GitLab
  • Sign in
  • garbus-wiki garbus-wiki
  • Project information
    • Project information
    • Activity
    • Labels
    • Planning hierarchy
    • Members
  • Repository
    • Repository
    • Files
    • Commits
    • Branches
    • Tags
    • Contributors
    • Graph
    • Compare
  • Issues 35
    • Issues 35
    • List
    • Boards
    • Service Desk
    • Milestones
  • Merge requests 0
    • Merge requests 0
  • CI/CD
    • CI/CD
    • Pipelines
    • Jobs
    • Schedules
  • Deployments
    • Deployments
    • Environments
    • Releases
  • Monitor
    • Monitor
    • Incidents
  • Analytics
    • Analytics
    • Value stream
    • CI/CD
    • Repository
  • Wiki
    • Wiki
  • Snippets
    • Snippets
  • Activity
  • Graph
  • Create a new issue
  • Jobs
  • Commits
  • Issue Boards
Collapse sidebar
  • GarbUs
  • garbus-wikigarbus-wiki
  • Wiki
  • banco_dados

banco_dados · Changes

Page history
Update banco_dados authored Jun 03, 2021 by Mario A. S. S. De Araujo's avatar Mario A. S. S. De Araujo
Show whitespace changes
Inline Side-by-side
banco_dados.md
View page @ b03c0c64
...@@ -5,6 +5,174 @@ ...@@ -5,6 +5,174 @@
Aqui deve ser explicado com modelos e explicações como o Banco de Dados foi construido, onde se deve focar em: Aqui deve ser explicado com modelos e explicações como o Banco de Dados foi construido, onde se deve focar em:
##### Banco de dados: **PostgreSQL**
* Como ele foi desenvolvido, com Imagens e Diagramas * Como ele foi desenvolvido, com Imagens e Diagramas
* o Collections(Entities) * o Collections(Entities)
* o ScriptSQL * o ScriptSQL
##### Script SQL para criação do schema inicial do banco de dados:
```
CREATE TABLE IF NOT EXISTS TYPES_EVENTS (
ID SERIAL PRIMARY KEY,
NAME VARCHAR NOT NULL,
DESCRIPTION VARCHAR
);
CREATE TABLE IF NOT EXISTS ZONES (
ID SERIAL PRIMARY KEY,
NAME VARCHAR NOT NULL NOT NULL,
DESCRIPTION VARCHAR NOT NULL,
LONGITUDE NUMERIC,
LATITUDE NUMERIC
);
CREATE TABLE IF NOT EXISTS TRASH_STATUS (
ID SERIAL PRIMARY KEY,
NAME VARCHAR NOT NULL,
DESCRIPTION VARCHAR NOT NULL
);
CREATE TABLE IF NOT EXISTS TYPE_TRASH (
ID SERIAL PRIMARY KEY,
NAME VARCHAR NOT NULL,
DESCRIPTION VARCHAR NOT NULL
);
CREATE TABLE IF NOT EXISTS PROFILES (
ID SERIAL PRIMARY KEY,
NAME VARCHAR NOT NULL,
DESCRIPTION VARCHAR NOT NULL
);
CREATE TABLE IF NOT EXISTS EVENTS (
ID SERIAL PRIMARY KEY,
DESCRIPTION VARCHAR,
CREATION_DATE TIMESTAMP NOT NULL,
PROBLEM_STATUS VARCHAR NOT NULL,
ID_TYPE_EVENTS INTEGER
);
ALTER TABLE EVENTS ADD CONSTRAINT FK_TYPE_EVENTS
FOREIGN KEY (ID_TYPE_EVENTS)
REFERENCES TYPES_EVENTS (ID);
CREATE TABLE IF NOT EXISTS BUILDINGS (
ID SERIAL PRIMARY KEY,
NAME VARCHAR NOT NULL,
LONGITUDE NUMERIC NOT NULL,
LATITUDE NUMERIC NOT NULL,
ID_ZONE INTEGER NOT NULL
);
ALTER TABLE BUILDINGS ADD CONSTRAINT FK_BUILDINGS_ZONES
FOREIGN KEY (ID_ZONE)
REFERENCES ZONES (ID);
CREATE TABLE IF NOT EXISTS USERS (
ID SERIAL PRIMARY KEY,
EMAIL VARCHAR,
NAME VARCHAR NOT NULL,
LOGIN VARCHAR NOT NULL,
PASSWORD VARCHAR NOT NULL,
BLOCKED BOOLEAN NOT NULL DEFAULT FALSE,
DT_REGISTER TIMESTAMP NOT NULL,
ID_PROFILE INTEGER
);
ALTER TABLE USERS ADD CONSTRAINT FK_USERS_PROFILES
FOREIGN KEY (ID_PROFILE)
REFERENCES PROFILES (ID);
CREATE TABLE IF NOT EXISTS USER_ZONE (
ID SERIAL PRIMARY KEY,
ID_USER INTEGER,
ID_ZONE INTEGER
);
ALTER TABLE USER_ZONE ADD CONSTRAINT FK_USER_ZONE
FOREIGN KEY (ID_USER)
REFERENCES USERS (ID);
ALTER TABLE USER_ZONE ADD CONSTRAINT FK_ZONE_USER
FOREIGN KEY (ID_ZONE)
REFERENCES ZONES (ID);
CREATE TABLE IF NOT EXISTS TRASHES (
ID SERIAL PRIMARY KEY,
BRAND VARCHAR NOT NULL,
DESCRIPTION VARCHAR NOT NULL,
CAPACITY FLOAT NOT NULL,
OCCUPATION FLOAT NOT NULL,
ID_STATUS INTEGER,
ID_TYPE INTEGER,
ID_BUILDING INTEGER,
ID_ZONE INTEGER,
LOCAL_DESCRIPTION VARCHAR,
LONGITUDE NUMERIC,
LATITUDE NUMERIC
);
ALTER TABLE TRASHES ADD CONSTRAINT FK_TRASHES_BUILDINGS
FOREIGN KEY (ID_BUILDING)
REFERENCES Buildings (ID);
ALTER TABLE TRASHES ADD CONSTRAINT FK_TYPE_LIV
FOREIGN KEY (ID_TYPE)
REFERENCES TYPE_TRASH (ID);
ALTER TABLE TRASHES ADD CONSTRAINT FK_TRASH_STATUS
FOREIGN KEY (ID_STATUS)
REFERENCES TRASH_STATUS (ID);
ALTER TABLE TRASHES ADD CONSTRAINT FK_ZONES_TRASHES
FOREIGN KEY (ID_ZONE)
REFERENCES ZONES (ID);
ALTER TABLE TRASHES ADD CONSTRAINT TRASH_BUILDING_OR_ZONE
CHECK (ID_ZONE IS NULL OR ID_BUILDING IS NULL);
CREATE TABLE IF NOT EXISTS TRASHES_EVENTS (
ID SERIAL PRIMARY KEY,
ID_EVENT INTEGER,
ID_TRASH INTEGER,
ID_USER INTEGER,
OCCUPATION FLOAT,
OTHERS VARCHAR,
DATE TIMESTAMP NOT NULL
);
ALTER TABLE TRASHES_EVENTS ADD CONSTRAINT FK_TRASHES_EVENTS_EVENTS
FOREIGN KEY (ID_EVENT)
REFERENCES EVENTS (ID);
ALTER TABLE TRASHES_EVENTS ADD CONSTRAINT FK_TRASHES_EVENTS_USERS
FOREIGN KEY (ID_USER)
REFERENCES USERS (ID);
ALTER TABLE TRASHES_EVENTS ADD CONSTRAINT FK_TRASHES_EVENTS_TRASH
FOREIGN KEY (ID_TRASH)
REFERENCES TRASHES (ID);
CREATE TABLE IF NOT EXISTS TRASHES_THRESHOLD (
ID SERIAL PRIMARY KEY,
MAX_OCCUPATION FLOAT,
COLOR VARCHAR NOT NULL,
ID_TRASH INTEGER NOT NULL
);
```
\ No newline at end of file
Clone repository
  • Backend
  • Gerenciamento do Projeto
  • Solução de Problemas: Prettier e quebras de linha
  • Utilizando a wiki
    • adicionando imagens
    • escrevendo em markdown
    • wiki no editor de texto
  • Workshops
  • arquitetura
  • banco_dados
  • configuracao
  • Home
  • horarios
  • instalacao
  • mockups
  • requisitos
View All Pages