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...