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

Os dados cadastrados não aparecem no MySQL.

Olá! O programa executa todo certinho (acredito eu). Porém, quando verifico pelo MySQL, não tem nenhum dado cadastrado. No MySql:

Os meus códigos estão assim:

pom.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>br.com.alura</groupId>
  <artifactId>loja</artifactId>
  <version>1.0-SNAPSHOT</version>
  <packaging>jar</packaging>

  <name>loja</name>
  <url>http://maven.apache.org</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>

    <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-entitymanager -->
    <dependency>
      <groupId>org.hibernate</groupId>
      <artifactId>hibernate-entitymanager</artifactId>
      <version>5.6.15.Final</version>
    </dependency>

    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>8.0.33</version>
    </dependency>

    <dependency>
      <groupId>javax.persistence</groupId>
      <artifactId>javax.persistence-api</artifactId>
      <version>2.2</version>
    </dependency>

  </dependencies>
</project>

persistence.xml:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.2"
             xmlns="http://xmlns.jcp.org/xml/ns/persistence"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_2.xsd">

             <persistence-unit name="loja" transaction-type="RESOURCE_LOCAL">
<!--                 O hibernate faz automaticamente mas outras aplicações, podem não fazer.-->
<!--                 <class>br.com.alura.loja.modelo.Produto</class>-->
                 <properties>
                     <property name="javax.persistence.jdbc.driver" value="com.mysql.cj.jdbc.Driver" />
                     <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/loja" />
                     <property name="javax.persistence.jdbc.user" value="max" />
                     <property name="javax.persistence.jdbc.password" value="31620303Mx-" />

                     <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL8Dialect" />
                 </properties>

             </persistence-unit>
</persistence>

cadastroDeProduto.java:

package br.com.alura.loja.testes;

import br.com.alura.loja.modelo.Produto;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import java.math.BigDecimal;

public class CadastroDeProduto {
    public static void main(String[] args) {

        Produto celular = new Produto();
        celular.setNome("iPhone 15 Pro Max");
        celular.setDescricao("O melhor do mercado.");
        celular.setPreco(new BigDecimal(3500));

        EntityManagerFactory factory = Persistence.createEntityManagerFactory("loja");
        EntityManager em = factory.createEntityManager();
        em.persist(celular);
    }
}

Produto.java:

package br.com.alura.loja.modelo;

import javax.persistence.*;
import java.math.BigDecimal;

@Entity
@Table(name = "produtos")
public class Produto {

    @Id //Informa que é a chave primária
    @GeneratedValue(strategy = GenerationType.IDENTITY) //Informa que o banco de dados que a gerará e a forma como será gerada.
    private Long id;
    private String nome;
//    @Column(name = "desc") quando o nome da coluna for diferente do atributo.
    private String descricao;
    private BigDecimal preco;

getters e setters...
1 resposta
solução!

O código passou a funcionar da seguinte forma:

package br.com.alura.loja.testes;

import br.com.alura.loja.modelo.Produto;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import java.math.BigDecimal;

public class CadastroDeProduto {
    public static void main(String[] args) {
        EntityManagerFactory factory = Persistence.createEntityManagerFactory("loja");
        EntityManager em = factory.createEntityManager();

        try {
            em.getTransaction().begin(); 

            Produto celular = new Produto();
            celular.setNome("iPhone 15 Pro Max");
            celular.setDescricao("O melhor do mercado.");
            celular.setPreco(new BigDecimal(3500));

            em.persist(celular); 

            em.getTransaction().commit(); 
            System.out.println("Produto cadastrado com sucesso!");
        } catch (Exception e) {
            e.printStackTrace();
            // Handle exceptions if necessary
            if (em.getTransaction().isActive()) {
                em.getTransaction().rollback(); 
            }
        } finally {
            em.close(); // Close EntityManager
            factory.close(); 
        }
    }
}