An open API service indexing awesome lists of open source software.

https://github.com/lmuffato/practice-sequelize-associations-trybe

Projeto para praticar sequelize - Bloco 29: Arquitetura: SOLID e ORM
https://github.com/lmuffato/practice-sequelize-associations-trybe

api back-end crud database express mysql orm pratice pratice-project sequelize solid sql

Last synced: about 2 months ago
JSON representation

Projeto para praticar sequelize - Bloco 29: Arquitetura: SOLID e ORM

Awesome Lists containing this project

README

          

Esse é um projeto para o conteúdo de `ORM - Associations`
### Antes de iniciar

Rode o `npm install`.

### COMEÇANDO O PROJETO

Nesse projeto vamos criar uma API que será responsável pela gestão de um sistema de saúde. Nesse sistema terão pacientes, cada um com seu plano. Cada paciente pode ter realizado várias cirurgias, que por sua vez, devem ser listadas e categorizadas. O diagrama abaixo demonstra como o banco de dados se comportará:

![Diagrama](images/diagrama3.png)

Este repositório ja contém alguns arquivos padrões, ao executar `npm install` as seguintes dependências foram instaladas:

- express

- nodemon

- sequelize mysql2

- sequelize-cli

Será necessário configurar o arquivo `config/config.json` com os dados de seu servidor.

Após, utilize os comandos:

- `npx sequelize db:create`
- `npx sequelize db:migrate`
- `npx sequelize db:seed:all`

Esses comandos vão criar respectivamente, a `database`, as `tables` e após, inserir dados exemplos nas tabelas.

As tabelas criadas são:

- Patients
- Patients_surgeries
- Plans
- Surgeries

Feito isso, ja podem ser realizados os exercícios abaixo.

#### Exercício 1

Crie o model de `Plans`.

#### Exercício 2

Crie o model de `Patients`.

#### Exercício 3

Crie o model de `Surgeries`.

#### Exercício 4

Crie o model de `Patient_surgeries`.

#### Exercício 5

Crie um endpoint que liste todos os pacientes e seus respectivos planos.

#### Exercício 6

Crie um endpoint que liste todos os pacientes e suas respectivas cirurgias realizadas.

#### Exercício 7

Crie um endpoint que de acordo com o id de um plano, que deve ser recebido via requisição, liste os pacientes que o possuem.

### Bônus

#### Exercício 1

Crie um endpoint capaz de adicionar um novo paciente.

#### Exercício 2

Crie um endpoint que liste todos os pacientes e suas cirurgias realizadas, mas oculte o nome do médico responsável.

#### Exercício 3

Crie um endpoint que de acordo com o nome do médico, que deve ser recebido via requisição, liste todas as cirurgias realizadas pelo mesmo, um get na url `http://localhost:3000/surgeries/Rey%20Dos%20Santos`deve retornar as cirurgias realizadas pelo médico `Rey Dos Santos`.