Olá desenvolvedor, pronto para participar do nosso processo de recrutamento para vaga de Estágio em Análise de Dados?
- Inclusão, exclusão e alteração de grande massa de dados via arquivos (Excel, CSV, JSON ou similar);
- Prestar auxílio no gerenciamento de cadastros realizados através das ferramentas internas.
- Cursando 3º Semestre ou superior em Banco de Dados (ou curso relacionado à TI com ênfase em Banco de Dados);
- Conhecimentos intermediários em SGBD e SQL;
- Conhecimentos básicos em Python (para auxiliar na automatização de tarefas);
- Perfil analítico e comunicativo.
Conhecimentos em:
- Nodejs
- PHP
- Postgres
- MongoDB
- Git
- Docker
- Residir no vale do paraíba ou nas proximidades.
Através desse teste iremos analisar as seguintes competências:
- Gerenciamento e análise de dados;
- Conhecimentos em estrutura e modelagem de banco de dados;
- Conhecimentos em lógica de programação;
- Criatividade na resolução de problemas.
Imagine que você precise modelar o banco de dados de um sistema cuja finalidade é disparar alertas de raios via email, sms, push, voz ou whatsapp para determinados contatos de regiões específicas, e tudo isso deve ser armazenado de forma íntegra, ou seja, não podemos ter duplicação de dados, inconsistências e repetições.
Nesse banco de dados deve-se armazenar as seguintes informações:
- Nome, números de telefone e emails dos contatos que devem receber os alertas, as regiões escolhidas e as configurações de envio para cada um deles, seguindo as seguintes especificações:
-
Você deve armazenar o nome do contato que vai receber o alerta, o email e o número de telefone (caso o contato possua estes dados);
-
Cada contato pode ter um ou mais números de telefone cadastrados e o número obrigatoriamente deve conter ddi e ddd;
-
Cada contato pode ter um ou mais emails cadastrados;
-
O contato pode receber alerta dos seguintes tipos: email, sms, voz, push notification e whatsapp;
-
Deve ser definido o período em que o contato vai receber o alerta. Ele deve poder escolher em quais dias da semana ele deseja ser alertado e em qual intervalo de horário.
-
Deve-se ter uma tabela para armazenar os nomes das localidades que o contato deseja receber alertas;
-
Cada localidade pode estar em uma ou mais configurações de envio de alerta;
-
Existem três tipos de alertas que o contato pode receber: verde, amarelo e vermelho.
-
O cadastro de um alerta não necessariamente será feito em todos os emails e telefones cadastrados para o contato, no arquivo contacts.xlsx está especificado qual email e/ou telefone deverá receber alertas da localidade;
-
É importante que cada configuração de envio de alerta tenha um período de envio único, para que a sua customização não interfira nas outras configurações de envio;
-
Deve ser possível registrar para que ele receba qualquer um desses tipos de alertas, independente da combinação, cada contato pode receber alerta de uma ou mais localidades diferentes, de um ou mais tipos diferentes.
-
Só é possível cadastrar a mesma localidade para um mesmo contato se for para um tipo de envio diferente, por exemplo, se ele já vai receber alerta da localidade X via SMS, só poderá registrar a mesma localidade para um tipo que seja diferente de SMS.
Obs: As tabelas não necessariamente precisam ser como está no diagrama. Lembre-se, o diagrama é apenas um auxílio. Caso seja preciso criar novas tabelas por conta da normalização dos dados, não há problema :D
-
Fazer um fork desse projeto no seu github;
-
Desenvolva! Você terá 7 dias a partir da data do envio do desafio.
-
Criar o banco de dados utilizando o SGBD que quiser, mas achamos o uso do Postgres mais interessante :D
-
Desenvolver um script em Python ou Nodejs para realizar a inserção dos dados do arquivo contacts.xlsx no banco de dados;
-
Nos enviar um pull request contendo o arquivo .sql com a criação das tabelas, o script criado para realizar a inserção no banco e um arquivo em markdown chamado PROJECT.md contando um pouco sobre o seu desenvolvimento para o teste e como podemos testá-lo :D
-
Preencha o formulario.
Boa sorte!
Qualquer dúvida entre em contato com nossa equipe.