Desenvolva uma aplicação que realize as operações de CRUD para a entidade Integrante
e Banda
.
A funcionalidade precisa estar disponível com UI (interface para o usuário) com um template usável.
As demais informações podem ser inseridas via script sql
.
class Integrante{
private int id;
private String nome;
private LocalDate dataDeNascimento;
private CPF cpf = new CPF("");
}
class Banda{
private int id;
private String localDeOrigem;
private String nomeFantasia;
private List<Integrante> integrantes;
}
Esta atividade prática está planejada para ser executada em equipes com três ou quatro pessoas. Toda a atividade deverá ser executada o intervalo das aulas e quando o tempo se esgotar as equipes devem fazer a entrega da respectiva atividade. Cada equipe deve fazer o fork deste projeto e implementar sua própria solução.
Caso surja alguma dúvida no desenvolvimento, falar de imediato via Slack.
Lembrete: Não guardem dúvidas, elas são como as dívidas. Acumulam-se e nos prejudicam :)
- RF01 - Implementar os métodos acessores para as classes
Integrante
eBanda
; - RF02 - Implementar a classe de acesso aos dados;
- RF03 - Na pasta banda, criar as páginas
edit.xhtml
elist.xhtml
para o arquivo de templatetemplate.xhtml
; - RF04 - Criar um Conversor para a classe
Integrante
; - RF05 - Adicionar um
selectOneMenu
na páginaedit.xhtml
da pasta banda. Deve ser possível selecionar umIntegrante
e associar sua instância ao atributointegrantes
da classeBanda
- RF06 - Criar as páginas para edição e listagem da entidade
Integrante
; - RF07 - Criar uma página que permita realizar uma busca por
CPF
; - RF08 - Criar uma página que permita realizar uma busca por
localDeOrigem
; - RF09 - Realizar o deploy da aplicação no Docker usando uma das images do Payara.
- RF10 - Realizar o deploy da aplicação usando o Docker Compose.
O script
para criação do banco.
CREATE TABLE integrante(
id serial PRIMARY KEY,
nome VARCHAR(50),
dataDeNascimento DATE,
CPF VARCHAR(15)
);
CREATE TABLE banda(
id SERIAL PRIMARY KEY,
localDeOrigem VARCHAR(100),
nomeFantasia VARCHAR(100)
);
CREATE TABLE integrante_banda(
id_banda int,
id_integrante int,
FOREIGN KEY (id_banda) REFERENCES banda(id) ON DELETE RESTRICT,
FOREIGN KEY (id_integrante) REFERENCES integrante(id) ON DELETE RESTRICT,
PRIMARY KEY(id_banda,id_integrante)
);