Erro de persistencia com JPA

Ola pessoal tudo bem? Estou tentando fazer a persistencia usando o JPA e ja tentei diversas formas e nao consigo, sempre lanca uma excepcao dizendo que a minha classe nao foi encontrada. Por favor quem puder me ajude, ABRACOS.

Persistencia.xml (Configuracao de persistencia )

você precisa adicionar no seu projeto uma biblioteca chamada Jandex, eu uso jandex2.0.4. Acabei de fazer o teste com de outra pessoa e era esse o problema.

1 curtida

Obrigado amigo, vou baixar entao, abracos.

Pesquisei como fazer a persistencia e vi que ha duas formas, um com session factory e outro com entitymanagerfactory, a fabrica de coneccao era totalmente diferente podi me explicar a diferenca?

http://www.guj.com.br/t/diferenca-entre-session-e-entitymanager-do-jpa/196561/2
Veja esse link que explica melhor, mas vou adiantar que entitymanagerfactory tem portabilidade e pode ser usado em outros programas que usam JPA como EclipseLink e o session factory apenas no Hibernate.

1 curtida

Ok, vou dar uma olhada, ja baixei a biblioteca jadex mas nao funcionou pode me enviar o link para baixar o jadex por favor amigo?

https://mvnrepository.com/artifact/org.jboss/jandex/2.0.4.Final depois clica em bundle que vai fazer o download.

1 curtida

Ja consigue amigao voce me salvou haha abracos:ok_hand:

1 curtida

@Heitor_Veloso cara desculpa ai, da outra vez eu consigue criar a tabela no banco, o problema agora e que esta dando um outro erro, da uma olha por favor

Camada de persistencia

coloca aqui para eu ver a classe JPAUtil, pois pelo erro apresentado parece ser algo nela, por exemplo se você tiver fechado a conexão ele não vai conseguir achar nada na linha abaixo.

Apos isso, o que eu fiz foi desmarcar a opcao de gerar tabela porque ja esta criado sera que esta correto?

Todos os directorios e bibliotecas do projecto abaixo:

aconselho a você fazer diferente conforme vou sugerir.

primeira alteração na classe persistência, vou postar só até onde deve mudar.

public class Persistencia {
          public static void main(String[] args) {
                JPAUtil conexao = new JPAUtil();
                EntityMangaer em = conexao.getEntityManager();
}

na segunda sugiro a alteração apenas onde está escrito static{} muda para o que vou postar abaixo, e caso continue dando o mesmo erro ou outro avisar;

public JPAUtil(){
           factory = Persistence.createEntityManagerFactory("JPAPU");
}

pois o que eu entendi vendo a sua classe JPAUtil você não chamava o “Persistence.createEntityManagerFactory(“JPAPU”);” antes de chamar o metodo que retorna o EntityManager.
Em relação ao none do xml está parcialmente correto, pois o certo é colocar no xml além de deixar em none o seguinte

<property name="hibernate.hbm2ddl.auto" value="update"/>

Ja fiz todas as mudanca mais continua o mesmo da uma olhada:

JPAUTIL:

PERSISTENCIA:

PERSISTENCE.xml:

Estou baseando em algumas apostilas e todos mostran da mesma forma e nenhum esta funcionando

no seu main acho que não há a necessidade do EntityTransaction tx, comenta a linha dele, depois muda tx.commit(); para em.commit(); e por fim troca JPAUtil.close(); para conexao.close(); Depois que fizer isso, continuando o erro da um novo print nele para eu ver onde está dando o erro.

Entao em.getTransaction( ).commit( ); porque o entitymanager so tem esse.
em.commit nao aparece.

ALTERACAO:

ERRO:

OBS:EU FIZ USANDO O HIBERNATE SEM ESPECIFICACAO DO JPA E FUNCIONOU TUDO, JA COM O JPA NAO FUNCIONA E NAO ENTENDO.

você está certo, me passa seu código todo que olha para você é só aqui no comentario uilizar a tag </> para colocar seu código, pois por imagem fica bem mais dificil até copiar tudo. Aqui não da para eu ver qual é a linha 27 da classe JPAUtil, pois apenas ela está sem a numeração, pode ser problema de ter posto o static, ou pode ser outro, pode ser até no mapeamento de veículo. Pois comparei o seu código com o meu e nas coisas que você postou não estou vendo diferenças.

ok vou enviar o meu codigo.

package com.model;

import com.factory.JPAUtil;
import javax.persistence.EntityManager;

/**
*

  • @author Programmer
    */
    public class Persistencia {

    public static void main(String[] args) {

     JPAUtil conexao = new JPAUtil();
     EntityManager em = conexao.getEntityManager();
    
     em.getTransaction().begin();
    
     Veiculo v = new Veiculo();
     v.setNome("BBBBBB");
     v.setMarca("AAAAAA");
    
     em.persist(v);
     em.getTransaction().commit();
     em.close();
    

    }
    }//FIM DA PERSISTENCIA

##############################################

package com.factory;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;

/**
*

  • @author Programmer
    */
    public class JPAUtil {

    private static EntityManagerFactory factory;

    public JPAUtil() {

     factory = Persistence.createEntityManagerFactory("JPAPU");
    

    }

    public EntityManager getEntityManager() {

     return factory.createEntityManager();
    

    }

    public static void close() {

     factory.close();
    

    }

}//FIM DO JPAUtil

###################################################

package com.model;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;

/**
*

  • @author Programmer
    */
    @Entity
    public class Veiculo {

    private int id;
    private String nome;
    private String marca;

    @Id
    @GeneratedValue
    public int getId() {
    return id;
    }

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

    public String getNome() {
    return nome;
    }

    public void setNome(String nome) {
    this.nome = nome;
    }

    public String getMarca() {
    return marca;
    }

    public void setMarca(String marca) {
    this.marca = marca;
    }

}//FIM DO VEICULO

Usei seu código e deu tudo certo.

abr 08, 2018 7:49:52 PM org.hibernate.ejb.HibernatePersistence logDeprecation
WARN: HHH015016: Encountered a deprecated javax.persistence.spi.PersistenceProvider [org.hibernate.ejb.HibernatePersistence]; use [org.hibernate.jpa.HibernatePersistenceProvider] instead.
abr 08, 2018 7:49:52 PM org.hibernate.ejb.HibernatePersistence logDeprecation
WARN: HHH015016: Encountered a deprecated javax.persistence.spi.PersistenceProvider [org.hibernate.ejb.HibernatePersistence]; use [org.hibernate.jpa.HibernatePersistenceProvider] instead.
abr 08, 2018 7:49:52 PM org.hibernate.ejb.HibernatePersistence logDeprecation
WARN: HHH015016: Encountered a deprecated javax.persistence.spi.PersistenceProvider [org.hibernate.ejb.HibernatePersistence]; use [org.hibernate.jpa.HibernatePersistenceProvider] instead.
abr 08, 2018 7:49:52 PM org.hibernate.jpa.internal.util.LogHelper logPersistenceUnitInformation
INFO: HHH000204: Processing PersistenceUnitInfo [
	name: JPAPU
	...]
abr 08, 2018 7:49:53 PM org.hibernate.Version logVersion
INFO: HHH000412: Hibernate Core {4.3.1.Final}
abr 08, 2018 7:49:53 PM org.hibernate.cfg.Environment <clinit>
INFO: HHH000206: hibernate.properties not found
abr 08, 2018 7:49:53 PM org.hibernate.cfg.Environment buildBytecodeProvider
INFO: HHH000021: Bytecode provider name : javassist
abr 08, 2018 7:49:53 PM org.hibernate.annotations.common.reflection.java.JavaReflectionManager <clinit>
INFO: HCANN000001: Hibernate Commons Annotations {4.0.4.Final}
abr 08, 2018 7:49:54 PM org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl configure
WARN: HHH000402: Using Hibernate built-in connection pool (not for production use!)
abr 08, 2018 7:49:54 PM org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl buildCreator
INFO: HHH000401: using driver [com.mysql.jdbc.Driver] at URL [jdbc:mysql://localhost:3306/teste1]
abr 08, 2018 7:49:54 PM org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl buildCreator
INFO: HHH000046: Connection properties: {user=root, password=****}
abr 08, 2018 7:49:54 PM org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl buildCreator
INFO: HHH000006: Autocommit mode: false
abr 08, 2018 7:49:54 PM org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl configure
INFO: HHH000115: Hibernate connection pool size: 20 (min=1)
abr 08, 2018 7:49:55 PM org.hibernate.dialect.Dialect <init>
INFO: HHH000400: Using dialect: org.hibernate.dialect.MySQL5Dialect
abr 08, 2018 7:49:55 PM org.hibernate.hql.internal.ast.ASTQueryTranslatorFactory <init>
INFO: HHH000397: Using ASTQueryTranslatorFactory
abr 08, 2018 7:49:56 PM org.hibernate.tool.hbm2ddl.SchemaUpdate execute
INFO: HHH000228: Running hbm2ddl schema update
abr 08, 2018 7:49:56 PM org.hibernate.tool.hbm2ddl.SchemaUpdate execute
INFO: HHH000102: Fetching database metadata
abr 08, 2018 7:49:56 PM org.hibernate.tool.hbm2ddl.SchemaUpdate execute
INFO: HHH000396: Updating schema
abr 08, 2018 7:49:56 PM org.hibernate.tool.hbm2ddl.DatabaseMetadata getTableMetadata
INFO: HHH000262: Table not found: Veiculo
abr 08, 2018 7:49:56 PM org.hibernate.tool.hbm2ddl.DatabaseMetadata getTableMetadata
INFO: HHH000262: Table not found: Veiculo
abr 08, 2018 7:49:56 PM org.hibernate.tool.hbm2ddl.DatabaseMetadata getTableMetadata
INFO: HHH000262: Table not found: Veiculo
abr 08, 2018 7:49:57 PM org.hibernate.tool.hbm2ddl.SchemaUpdate execute
INFO: HHH000232: Schema update complete
Hibernate: 
    insert 
    into
        Veiculo
        (marca, nome) 
    values
        (?, ?)

olhei no banco de dados e inseriu. Confere para mim se você tem 3 bibliotecas no seu projeto (jandex 2.0.4, Hibernate4.3x(JPA2.1) e diver JDBC do MySQL) e se você criou anteriormente o database no banco de dados, por exemplo eu usei <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/teste1"/> no persistence.xml, dei o nome da database de teste1.

o que coloquei no arquivo persistence.xml abaixo, lembrando de trocar os asteristicos em senha para a sua senha do banco de dados:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1" 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_1.xsd">
  <persistence-unit name="JPAPU" transaction-type="RESOURCE_LOCAL">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <class>com.model.Veiculo</class>
    <properties>
      <property name="hibernate.cache.provider_class" value="org.hibernate.cache.NoCacheProvider"/>
      <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/teste1"/>
      <property name="javax.persistence.jdbc.password" value="****"/>
      <property name="javax.persistence.jdbc.user" value="root"/>
      <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
      <property name="hibernate.show_sql" value="true"/>
      <property name="hibernate.format_sql" value="true"/>
      <property name="hibernate.hbm2ddl.auto" value="update"/>
    </properties>
  </persistence-unit>
</persistence>