Solucionado (ver solução)
Solucionado
(ver solução)
5
respostas

Arquivo data.sql

INSERT INTO TOPICO(titulo, mensagem, data_criacao, status, autor_id, curso_id) VALUES('Dúvida', 'Erro ao criar projeto', '2019-05-05 18:00:00', 'NAO_RESPONDIDO', 1, 1); INSERT INTO TOPICO(titulo, mensagem, data_criacao, status, autor_id, curso_id) VALUES('Dúvida 2', 'Projeto não compila', '2019-05-05 19:00:00', 'NAO_RESPONDIDO', 1, 1); INSERT INTO TOPICO(titulo, mensagem, data_criacao, status, autor_id, curso_id) VALUES('Dúvida 3', 'Tag HTML', '2019-05-05 20:00:00', 'NAO_RESPONDIDO', 1, 2);

Estou usando o MySqlServer como bd, porém não está inserindo essa parte do código.

O usuario e o Curso foi inserido no banco, menos topico

5 respostas

usuário e senha de conexão com o banco de dados

spring.datasource.username=root spring.datasource.password=root

url de conexão do banco de dados

spring.datasource.url=jdbc:mysql://localhost:3306/forum

apontamos para o JPA e Hibernate qual é o Dialeto do banco de dados

spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL8Dialect spring.jpa.database-platform=org.hibernate.dialect.MySQL8Dialect

deixamos o hibernate responsável por ler nossas entidades e criar as tabelas do nosso banco de dados automaticamente

spring.jpa.hibernate.ddl-auto=update

configuração do Hibernate para reconhecer o nome de tabelas em caixa alta

spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl

configurações de log

spring.jpa.show-sql=true spring.jpa.properties.hibernate.format_sql=true spring.jpa.properties.hibernate.show_sql=true spring.jpa.properties.hibernate.use_sql_comments=true

Necessario para iniciar o data.sql

spring.jpa.defer-datasource-initialization=true

package br.com.alura.forum.modelo;

import lombok.Data;

import javax.persistence.*; import java.time.LocalDateTime; import java.util.ArrayList; import java.util.List;

/**

  • Por exemplo, o atributo status é um enum, e quero que o hibernate grave no banco de dados o nome da constante
  • do enum, ao invés da ordem de declaração. Então, preciso colocar a anotação @Enumerated(), que, por padrão,
  • grava a ordem, mas, como eu não quero guardar a ordem, vou passar o valor STRING *
  • No caso do @ManyToOne, tem que passar uma propriedade, que é o mappedBy, para ele não achar que é um novo mapeamento
  • , porque na classe, e nela, a resposta, estará mapeado o relacionamento com o tópico. Então, mappedBy = "topico"
  • que é o nome do atributo lá na classe resposta */

@Entity public class Topico {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    private String titulo;
    private String mensagem;
    private LocalDateTime dataCriacao = LocalDateTime.now();
    @Enumerated(EnumType.STRING)
    private StatusTopico status = StatusTopico.NAO_RESPONDIDO;
    @ManyToOne
    private Usuario autor;
    @ManyToOne
    private Curso curso;
    @OneToMany(mappedBy = "topico")
    private List<Resposta> respostas = new ArrayList<>();

    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((id == null) ? 0 : id.hashCode());
        return result;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        Topico other = (Topico) obj;
        if (id == null) {
            if (other.id != null)
                return false;
        } else if (!id.equals(other.id))
            return false;
        return true;
    }

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getTitulo() {
        return titulo;
    }

    public void setTitulo(String titulo) {
        this.titulo = titulo;
    }

    public String getMensagem() {
        return mensagem;
    }

    public void setMensagem(String mensagem) {
        this.mensagem = mensagem;
    }

    public LocalDateTime getDataCriacao() {
        return dataCriacao;
    }

    public void setDataCriacao(LocalDateTime dataCriacao) {
        this.dataCriacao = dataCriacao;
    }

    public StatusTopico getStatus() {
        return status;
    }

    public void setStatus(StatusTopico status) {
        this.status = status;
    }

    public Usuario getAutor() {
        return autor;
    }

    public void setAutor(Usuario autor) {
        this.autor = autor;
    }

    public Curso getCurso() {
        return curso;
    }

    public void setCurso(Curso curso) {
        this.curso = curso;
    }

    public List<Resposta> getRespostas() {
        return respostas;
    }

    public void setRespostas(List<Resposta> respostas) {
        this.respostas = respostas;
    }

}

Oi Fernando,

Verifica qual erro acontece no console ao rodar a aplicação e posta aqui o log completo.

solução!

Consegui resolver já

Ah que ótimo então!

Bons estudos!