Solucionado (ver solução)
Solucionado
(ver solução)
1
resposta

Salva apenas um cadastro

Estou tentando salvar outro médico, mas não tá dando certo. Dá erro 500 Internal Server Error no Insomnia. O banco de dados que estou usando é o MySQL.

`    "timestamp": "2023-04-17T00:31:59.365+00:00",
"status": 500,
"error": "Internal Server Error",
"trace": "org.springframework.dao.DataIntegrityViolationException: could not execute statement; SQL [n/a]; constraint [medicos.email]\n\tat org.springframework.orm.jpa.vendor.HibernateJpaDialect.convertHibernateAccessException(HibernateJpaDialect.java:270)\n\tat 

"message": "could not execute statement; SQL [n/a]; constraint [medicos.email]",
"path": "/medicos"

Desconfio que seja algo relacionado à chave primária. Alguém poderia me ajudar?

package med.voll.api.medico;

import jakarta.persistence.*;
import lombok.AllArgsConstructor;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.NoArgsConstructor;
import med.voll.api.endereco.Endereco;

@Entity(name = "Medico")
@Table(name = "medicos")
@Getter
@NoArgsConstructor
@AllArgsConstructor
@EqualsAndHashCode(of = "id")
public class Medico {
    @Id @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String nome;
    private String email;
    private String crm;

    @Enumerated(EnumType.STRING)
    private Especialidade especialidade;

    @Embedded
    private Endereco endereco;


    public Medico(DadosCadastroMedico dados) {
        this.nome = dados.nome();
        this.email = dados.email();
        this.especialidade = dados.especialidade();
        this.crm = dados.crm();
        this.endereco = new Endereco(dados.endereco());
    }
}
1 resposta
solução!

Resolvido. Estava alterando apenas o nome, não tinha observado que email e CRM foram criados com a marcação de UNIQUE no banco de dados. Olhei o código de criação da tabela e entendi.