Foros del Web » Programación para mayores de 30 ;) » Java »

[SOLUCIONADO] java + hibernate + jpa

Estas en el tema de java + hibernate + jpa en el foro de Java en Foros del Web. Buenas noches tengo un problema supongo que simple, pero problema en fin. estoy arrancando con java, hibernate y jpa... tengo el siguiente error a ver ...
  #1 (permalink)  
Antiguo 22/08/2019, 17:14
 
Fecha de Ingreso: octubre-2010
Mensajes: 143
Antigüedad: 8 años, 10 meses
Puntos: 5
java + hibernate + jpa

Buenas noches tengo un problema supongo que simple, pero problema en fin.
estoy arrancando con java, hibernate y jpa...
tengo el siguiente error a ver si alguien me puede dar con alguna sugerencia, ya que no encuentro temas similares a este caso.

Código error por consola:
Ver original
  1. ERROR: CLIENT_PLUGIN_AUTH is required
  2. Exception in thread "main" org.hibernate.service.spi.ServiceException: Unable to create requested service [org.hibernate.engine.jdbc.env.spi.JdbcEnvironment]
  3.     at org.hibernate.service.internal.AbstractServiceRegistryImpl.createService(AbstractServiceRegistryImpl.java:275)
  4.     at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:237)
  5.     at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:214)
  6.     at org.hibernate.id.factory.internal.DefaultIdentifierGeneratorFactory.injectServices(DefaultIdentifierGeneratorFactory.java:152)
  7.     at org.hibernate.service.internal.AbstractServiceRegistryImpl.injectDependencies(AbstractServiceRegistryImpl.java:286)
  8.     at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:243)
  9.     at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:214)
  10.     at org.hibernate.boot.internal.InFlightMetadataCollectorImpl.<init>(InFlightMetadataCollectorImpl.java:175)
  11.     at org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:118)
  12.     at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.metadata(EntityManagerFactoryBuilderImpl.java:900)
  13.     at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:931)
  14.     at org.hibernate.jpa.HibernatePersistenceProvider.createEntityManagerFactory(HibernatePersistenceProvider.java:56)
  15.     at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:79)
  16.     at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:54)
  17.     at com.contable.test.TestPersona.main(TestPersona.java:19)
  18. Caused by: org.hibernate.exception.JDBCConnectionException: Error calling Driver#connect

y estas son las clases y archivo de configuración involucradas.
Código clase persona:
Ver original
  1. package com.contable.modelo.Persona;
  2.  
  3. import java.io.Serializable;
  4.  
  5. import javax.persistence.Column;
  6. import javax.persistence.Entity;
  7. import javax.persistence.GeneratedValue;
  8. import javax.persistence.GenerationType;
  9. import javax.persistence.Id;
  10. import javax.persistence.Table;
  11.  
  12.  
  13. @Entity
  14. @Table(name = "Persona")
  15. public class Persona implements Serializable{
  16.  
  17.     private static final long serialVersionUID = 1L;
  18.  
  19.     @Id
  20.     @GeneratedValue(strategy = GenerationType.IDENTITY) //autoincremental
  21.     private int id;
  22.    
  23.     @Column(name="empresa")
  24.     private int Empresa;
  25.    
  26.     //STRING
  27.     @Column(name="nombre", length=45)
  28.     private String nombre;
  29.     @Column(name="apellido", length=45)
  30.     private String apellido;
  31.     @Column(name="direccion", length=45)
  32.     private String direccion;
  33.     @Column(name="prov", length=30)
  34.     private String prov;
  35.     @Column(name="localidad", length=70)
  36.     private String localidad;
  37.     @Column(name="mail", length=70)
  38.     private String mail;
  39.     @Column(name="tel1", length=45)
  40.     private String tel1;
  41.     @Column(name="tel2", length=45)
  42.     private String tel2;
  43.    
  44.     @Column(name="condicion_iva", length=45)
  45.     private String condicion_iva;
  46.    
  47.     //BOOLEANO
  48.     @Column(name="proveedor")
  49.     private boolean proveedor;
  50.     @Column(name="cliente")
  51.     private boolean cliente;
  52.     @Column(name="eliminado")
  53.     private boolean eliminado;
  54.    
  55.    
  56.     //ENTERO
  57.     @Column (name="cp")
  58.     private int cp;
  59.    
  60.     //constructores getters y setters.     
  61. }
Código PERSISTENCIA.XML:
Ver original
  1. <?xml version="1.0" encoding="UTF-8"?>
  2.  
  3. <persistence xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4.              xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
  5.              version="2.0" xmlns="http://java.sun.com/xml/ns/persistence">
  6.  
  7.   <persistence-unit name="Persistencia">
  8.  
  9.   <!--  PERSISTENCIA DE CLASES -->
  10.   <!-- PAQUETE PERSONA-->    
  11.   <class> com.contable.modelo.Persona.Persona </class>
  12.    
  13.  
  14.  
  15.     <properties>
  16.     <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver" />
  17.         <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/dbcontable" />
  18.         <property name="hibernate.connection.username" value="root" />
  19.         <property name="hibernate.connection.password" value="ternario" />
  20.         <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" />
  21.         <property name="hibernate.show_sql" value="true"/>
  22.         <property name="hibernate.hbm2ddl.auto" value="update" />
  23.        
  24. <!-- <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
  25.         <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/dbcontable" />
  26.         <property name="javax.persistence.jdbc.user" value="root" />
  27.         <property name="javax.persistence.jdbc.password" value="ternario" />
  28.         <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" />
  29.         <property name="hibernate.show_sql" value="true" />
  30.         <property name="hibernate.hbm2ddl.auto" value="update" /> -->
  31.        
  32.     </properties>
  33.   </persistence-unit>
  34.  
  35. </persistence>
como se ve comente varias opciones de configuracion, en las pruebas, sin lograr conectar a la base, que supongo que es el problema.

codigo de prueba.
Código prueba:
Ver original
  1. package com.contable.test;
  2.  
  3.  
  4. import java.util.List;
  5.  
  6. import javax.persistence.EntityManager;
  7. import javax.persistence.EntityManagerFactory;
  8. import javax.persistence.Persistence;
  9.  
  10. import com.contable.modelo.Persona.Persona;
  11.  
  12. public class TestPersona {
  13.  
  14.     private static EntityManager manager;
  15.    
  16.     private static EntityManagerFactory emf;
  17.    
  18.     public static void main (String[] args) {
  19.         emf = Persistence.createEntityManagerFactory("Persistencia");
  20.         manager = emf.createEntityManager();
  21.        
  22.         List<Persona> list= (List<Persona>)manager.createQuery("FROM Persona").getResultList();
  23.         System.out.println("en la base de datos hay: "+list.size()+" empleados");
  24.     }
  25. }
la excepcion salta en la linea 19: con 'emf = Persistence.createEntityManagerFactory("Persistenc ia");'

y este es mi archivo pom.xml
Código POM.XML:
Ver original
  1. <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">
  2.   <modelVersion>4.0.0</modelVersion>
  3.   <groupId>com.ternario</groupId>
  4.   <artifactId>hib-jpa-contable</artifactId>
  5.   <version>1.0.0.1-SNAPSHOT</version>
  6.  
  7.   <dependencies>
  8.     <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-core -->
  9.         <dependency>
  10.             <groupId>org.hibernate</groupId>
  11.             <artifactId>hibernate-core</artifactId>
  12.             <version>5.4.4.Final</version>
  13.         </dependency>
  14.         <!-- https://mvnrepository.com/artifact/javax.persistence/persistence-api -->
  15.         <dependency>
  16.             <groupId>javax.persistence</groupId>
  17.             <artifactId>persistence-api</artifactId>
  18.             <version>1.0.2</version>
  19.         </dependency>
  20.         <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-entitymanager -->
  21.         <dependency>
  22.             <groupId>org.hibernate</groupId>
  23.             <artifactId>hibernate-entitymanager</artifactId>
  24.             <version>5.4.4.Final</version>
  25.         </dependency>
  26.         <!-- https://mvnrepository.com/artifact/com.h2database/h2 g
  27.         database como archivo.-->
  28.         <dependency>
  29.             <groupId>com.h2database</groupId>
  30.             <artifactId>h2</artifactId>
  31.             <version>1.4.199</version>
  32.             <scope>test</scope>
  33.         </dependency>
  34.        
  35.         <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
  36.         <dependency>
  37.             <groupId>mysql</groupId>
  38.             <artifactId>mysql-connector-java</artifactId>
  39.             <version>8.0.17</version>
  40.         </dependency>
  41.        
  42.   </dependencies>
  43.   <build>
  44.   <plugins>
  45.       <plugin>
  46.         <groupId>org.apache.maven.plugins</groupId>
  47.         <artifactId>maven-compiler-plugin</artifactId>
  48.         <version>3.8.1</version>
  49.         <configuration>
  50.           <source>1.8</source>
  51.           <target>1.8</target>
  52.         </configuration>
  53.       </plugin>
  54.     </plugins>
  55.    </build>
  56. </project>

Según la documentación, el error devuelto es error de conexión a la base, controlo con mucha atención, la configuración al la base esta bien cargada, supongo que puede ser alguna property mal expresada o alguna dependencia que este de maso o que falte, porque realmente no tengo idea que puede ser.
Si alguien cree tener alguna sugerencia, la escucho y pruebo para ver si avanzo con este tema.
Desde ya muchas gracias. un abrazo a todos.
  #2 (permalink)  
Antiguo 23/08/2019, 14:16
 
Fecha de Ingreso: octubre-2010
Mensajes: 143
Antigüedad: 8 años, 10 meses
Puntos: 5
Respuesta: java + hibernate + jpa

al archivo persistence.xml probé cargarlo tanto en:
src/main/resources/META-INF/persistence.xml, así como también
src/main/resources/WEB-INF/classes/META-INF/persistence.xml (acá, la consola me devolvia el mensaje de error que no encontraba el archivo META-INF/persistence.xml).

y todo el error anterior, sale con el persistence.xml desde la primera ruta.

por cierto, mi version de eclipse es 2018-12 (4.10)

Saludos.

Última edición por lucho248; 23/08/2019 a las 14:21
  #3 (permalink)  
Antiguo 27/08/2019, 15:11
 
Fecha de Ingreso: octubre-2010
Mensajes: 143
Antigüedad: 8 años, 10 meses
Puntos: 5
Respuesta: java + hibernate + jpa

buenas tardes, resulto ser un problema de versiones del mysql server... unifique la verision a 5.1.32, de la siguiente manera.
archivo pom:
Código XML:
Ver original
  1. <dependency>
  2.             <groupId>mysql</groupId>
  3.             <artifactId>mysql-connector-java</artifactId>
  4.            <!-- <version>8.0.17</version> --> //con esta da error
  5.             <version>5.1.32</version> //resolvi el problema.
  6.         </dependency>

y el mysql con :
SELECT version();

'5.1.73-community'

por si alguien le sirve de parámetro alguna vez. saludos.



La zona horaria es GMT -6. Ahora son las 06:04.